Получить значение поля с помощью курсора

Я создаю приложение, и у меня проблемы с Cursor. У меня есть SQLiteDatabase, который возвращает мне Cursor, когда я пытаюсь получить значения с помощью этой функции:

public Cursor fetchOption(long rowId) throws SQLException {

    Cursor mCursor = mDb.query(true, DATABASE_TABLE, new String[] {KEY_ROWID,
        KEY_TITLE, KEY_BODY}, KEY_ROWID + "=" + rowId, null,
        null, null, null, null);
    if (mCursor != null) {
        mCursor.moveToFirst();
    }
    return mCursor;

}

Я не знаю, как получить значение поля в Cursor. Если я сделаю это так:

String a = mOptionDb.fetchOption(0).getColumnName(0).toString();
String b = mOptionDb.fetchOption(0).getColumnName(1).toString();
String c = mOptionDb.fetchOption(0).getColumnName(2).toString();

Я получаю только имена столбцов (_id, title, body), но не значения. Любые предложения о том, как этого добиться?


person Michaël    schedule 24.05.2009    source источник


Ответы (3)


Я думаю, вы можете забыть о проверке на ноль.

Вместо этого проверьте, есть ли данные, а затем получите доступ к столбцам с помощью курсора:

Cursor cursor = fetchOption(0);

if (cursor.moveToFirst()) // data?
   System.out.println(cursor.getString(cursor.getColumnIndex("title")); 

cursor.close(); // that's important too, otherwise you're gonna leak cursors

Также может иметь смысл прочитать учебник по Android. Учебное пособие по блокноту, кажется, отвечает всем требованиям: http://developer.android.com/guide/tutorials/notepad/index.html

person Mariano Kamp    schedule 24.05.2009
comment
Спасибо за помощь. Теперь это работает. Я забываю каждый доступ, чтобы закрыть курсор... - person Michaël; 25.05.2009
comment
каждый раз, когда у меня возникает эта проблема, я возвращаюсь сюда и понимаю, что забыл cursor.moveToFirst(). Благодарность! - person user1549672; 03.08.2013

Вы можете использовать методы get* Cursor для извлечения значений из результата:

long id = cursor.getLong(cursor.getColumnIndex("_id"));
long title = cursor.getString(cursor.getColumnIndex("title"));
...

Лучшей практикой, очевидно, является использование констант (часто предоставляемых ContentProviders) вместо вызовов getColumnIndex с жестко заданными строками.

person Josef Pfleger    schedule 24.05.2009
comment
с частью: int a = mOptionDb.fetchOption(0).getColumnIndex(title); Я получаю 1. Но с mOptionDb.fetchOption(0).getString(a); Я получаю сообщения об ошибках: ERROR/AndroidRuntime(628): Неперехваченный обработчик: выход основного потока из-за необработанного исключения ERROR/AndroidRuntime(628): android.database.CursorIndexOutOfBoundsException: Запрошен индекс 0, размер 0 Как будто данных нет ?! - person Michaël; 24.05.2009

Вы можете использовать этот механизм.

Cursor record=db.test(finalDate);     
if(record.getCount()!=0){
    if(record.moveToFirst()){
        do{               
            Imgid1=record.getString(record.getColumnIndex(Database.PHOTO));                
        }while(record.moveToNext());                          
    } 
    record.close();        
}
person Community    schedule 26.09.2012