1

これは私が得ているエラーです:

07-20 11:04:45.564: E/AndroidRuntime(1905): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.dosemanager1.ui/com.dosemanager.ui.ActivityDisplayMedicineDetails}: android.database.CursorIndexOutOfBoundsException: Index 0 requested, with a size of 0

特定の薬の詳細を更新したい。だから、私はこのコードを使用します:

public int updateMedicine(MedicineDetails medicine, String oldTitle){
    SQLiteDatabase db = this.getWritableDatabase();

    ContentValues values = new ContentValues();
    values.put(KEY_DOSE_NAME, medicine.getDoseName());
    values.put(KEY_DOSE_SCHEDULE, medicine.getDoseSchedule().getTimeInMillis());
    values.put(KEY_DOSE_REPEAT, medicine.getDoseRepeat());
    values.put(KEY_DOSE_FREQUENCY, medicine.getDoseFrequency());
    values.put(KEY_DOSE_OTHER_NOTES, medicine.getOtherNotes());

    // updating row
    return db.update(TABLE_MEDICINES, values, KEY_DOSE_NAME + " = ?",
            new String[] { oldTitle });
}

現在、他の場所で作成したトーストで詳細が更新されていることがわかりますが、更新された詳細を表示しようとすると、CursorIndexOutOfBounds例外が発生します。

MedicineDetailsこれは、単一のオブジェクトを返すための私のコードです:

public MedicineDetails getSingleMedicine(String title) {
    SQLiteDatabase db = this.getReadableDatabase();
    Calendar cal = Calendar.getInstance();
    Cursor cursor = db.query(TABLE_MEDICINES, new String[] { KEY_ID_DOSE, KEY_DOSE_NAME, KEY_DOSE_SCHEDULE, 
            KEY_DOSE_REPEAT, KEY_DOSE_FREQUENCY, KEY_DOSE_OTHER_NOTES},
            KEY_DOSE_NAME + "=?",
            new String[] { title }, null, null, null);

    if (cursor != null)
        cursor.moveToFirst();

    cal.setTimeInMillis(cursor.getLong(2));
    System.out.println(cal.getTime());

    MedicineDetails singleDetail = new MedicineDetails(cursor.getString(1), cal,
            cursor.getString(3), cursor.getString(4), cursor.getString(5));

    return singleDetail;
}

これは私がテーブルを作成した場所です:

String CREATE_MEDICINES_TABLE = "CREATE TABLE " + TABLE_MEDICINES + "("
            + KEY_ID_DOSE + " INTEGER PRIMARY KEY," + KEY_DOSE_NAME + " TEXT,"              
            + KEY_DOSE_SCHEDULE + " INTEGER, " + KEY_DOSE_REPEAT + " TEXT," 
            + KEY_DOSE_FREQUENCY + " TEXT," + KEY_DOSE_OTHER_NOTES + " TEXT" + ");";
    db.execSQL(CREATE_MEDICINES_TABLE);     

同じコードは、編集していない薬の詳細を表示するために完全に機能します。というわけで、更新に問題があると思います。

同様の問題をいくつか読んだことがありますが、他の場所の回答では問題を解決できませんでした。私はどんな間違いをしていますか?

4

1 に答える 1

3

クエリによって返されるカーソルは空の場合がありますが、null になることはありません。空の場合はmoveToFirst()false を返すため、コードは次のようになります。

MedicineDetails singleDetail;
if (cursor.moveToFirst())
{
    cal.setTimeInMillis(cursor.getLong(2));
    System.out.println(cal.getTime());

    MedicineDetails singleDetail = new MedicineDetails(cursor.getString(1), cal,
        cursor.getString(3), cursor.getString(4), cursor.getString(5));
}

return singleDetail;
于 2013-07-20T06:05:04.550 に答える