Код: Выделить всё
public void addRec(int id) {
String query = "SELECT " + COLUMN_MENU_ID + ", "
+ COLUMN_MENU_NAME + ", "
+ COLUMN_MENU_SELL + ", "
+ COLUMN_MENU_IMG + " FROM " + DB_MENU_AP;
Cursor cursor = myDataBaseJackie.rawQuery(query, null);
cursor.moveToPosition(id-1);
Cursor cd = myDataBaseJackie.query(DB_TRASH_AP, null, null, null, null, null, null);
cd.moveToPosition(id-1);
//добавляем данные в корзину
int item_id = cursor.getInt(cursor.getColumnIndex(COLUMN_MENU_ID));
String item_name = cursor.getString(cursor.getColumnIndex(COLUMN_MENU_NAME));
int item_sell = cursor.getInt(cursor.getColumnIndex(COLUMN_MENU_SELL));
int item_img = cursor.getInt(cursor.getColumnIndex(COLUMN_MENU_IMG));
ContentValues cv = new ContentValues();
cv.put(COLUMN_TRASH_ID, item_id);
cv.put(COLUMN_TRASH_NAME, item_name);
cv.put(COLUMN_TRASH_KOL, 1);
cv.put(COLUMN_TRASH_SELL, item_sell);
cv.put(COLUMN_TRASH_IMG, item_img);
long fail = myDataBaseJackie.insert(DB_TRASH_AP, null, cv);
//Обновляем количество элемента на единицу больше
if (fail == -1){
ContentValues cv1 = new ContentValues();
int kol = cd.getInt(cd.getColumnIndex(COLUMN_TRASH_KOL))+1;
cv1.put(COLUMN_TRASH_KOL, kol );
myDataBaseJackie.update(DB_TRASH_AP, cv1, "_id = ?",
new String[] { String.valueOf(id) });
}
cursor.close();
cd.close();
}
Код: Выделить всё
02-21 14:50:07.823: D/AndroidRuntime(364): Shutting down VM
02-21 14:50:07.823: W/dalvikvm(364): threadid=1: thread exiting with uncaught exception (group=0x40015560)
02-21 14:50:07.833: E/AndroidRuntime(364): FATAL EXCEPTION: main
02-21 14:50:07.833: E/AndroidRuntime(364): android.database.CursorIndexOutOfBoundsException: Index 1 requested, with a size of 1
02-21 14:50:07.833: E/AndroidRuntime(364): at android.database.AbstractCursor.checkPosition(AbstractCursor.java:580)
02-21 14:50:07.833: E/AndroidRuntime(364): at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:214)
02-21 14:50:07.833: E/AndroidRuntime(364): at android.database.AbstractWindowedCursor.getInt(AbstractWindowedCursor.java:84)
02-21 14:50:07.833: E/AndroidRuntime(364): at com.sunteam.jackie.DataBaseHelper.addRec(DataBaseHelper.java:169)
02-21 14:50:07.833: E/AndroidRuntime(364): at com.sunteam.jackie.MySimpleCursorAdapter$1.onClick(MySimpleCursorAdapter.java:50)
02-21 14:50:07.833: E/AndroidRuntime(364): at android.view.View.performClick(View.java:2485)
02-21 14:50:07.833: E/AndroidRuntime(364): at android.view.View$PerformClick.run(View.java:9080)
02-21 14:50:07.833: E/AndroidRuntime(364): at android.os.Handler.handleCallback(Handler.java:587)
02-21 14:50:07.833: E/AndroidRuntime(364): at android.os.Handler.dispatchMessage(Handler.java:92)
02-21 14:50:07.833: E/AndroidRuntime(364): at android.os.Looper.loop(Looper.java:123)
02-21 14:50:07.833: E/AndroidRuntime(364): at android.app.ActivityThread.main(ActivityThread.java:3683)
02-21 14:50:07.833: E/AndroidRuntime(364): at java.lang.reflect.Method.invokeNative(Native Method)
02-21 14:50:07.833: E/AndroidRuntime(364): at java.lang.reflect.Method.invoke(Method.java:507)
02-21 14:50:07.833: E/AndroidRuntime(364): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
02-21 14:50:07.833: E/AndroidRuntime(364): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
02-21 14:50:07.833: E/AndroidRuntime(364): at dalvik.system.NativeStart.main(Native Method)
02-21 14:50:07.833: E/AndroidRuntime(364): android.database.CursorIndexOutOfBoundsException: Index 1 requested, with a size of 1
Проблема вроде в том, что я пытаюсь обратиться к объекту, которого нет в массиве? Хотя я указываю точно на строку в базе cd.moveToPosition(id-1);
Это так? Как вылечить?
Если вы видите перед собой говно код, не удивляйтесь я начинающий) Очень надеюсь на помощь.