Получить значение поля с помощью курсора
Я создаю приложение, и у меня проблемы с 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
), но не значения. Любые предложения о том, как достичь этого?
Ответы
Ответ 1
Я думаю, что вы можете забыть о проверке на ноль.
Вместо этого проверьте, есть ли данные, а затем получите доступ к столбцам с помощью курсора:
Cursor cursor = fetchOption(0);
if (cursor.moveToFirst()) // data?
System.out.println(cursor.getString(cursor.getColumnIndex("title"));
cursor.close(); // that important too, otherwise you're gonna leak cursors
Возможно, имеет смысл прочитать учебник по Android. Учебное пособие для блокнота, кажется, отвечает всем требованиям: http://developer.android.com/guide/tutorials/notepad/index.html
Ответ 2
Вы можете использовать методы Cursor
get*
для извлечения значений из результата:
long id = cursor.getLong(cursor.getColumnIndex("_id"));
long title = cursor.getString(cursor.getColumnIndex("title"));
...
Лучшей практикой является, очевидно, использование констант (часто предоставляемых ContentProviders) вместо вызовов на getColumnIndex
с жестко закодированными строками.
Ответ 3
Вы можете использовать этот механизм.
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();
}