Obter o valor do campo com um Cursor
-
05-09-2019 - |
Pergunta
Eu estou criando um aplicativo e não tenho problemas com Cursor
. Eu tenho um SQLiteDatabase
que me retorna um Cursor
quando tento buscar os valores com esta função:
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;
}
Eu não sei como obter o valor do campo na Cursor
. Se eu fizer isso assim:
String a = mOptionDb.fetchOption(0).getColumnName(0).toString();
String b = mOptionDb.fetchOption(0).getColumnName(1).toString();
String c = mOptionDb.fetchOption(0).getColumnName(2).toString();
Eu só obter o nome das colunas (_id, title, body
), mas não os valores. Todas as sugestões sobre como conseguir isso?
Solução
Eu acho que você pode esquecer sobre a verificação de nulo.
Em vez disso verificar se há dados e, em seguida, acessar as colunas usando o cursor:
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
Ele também pode fazer sentido para ler um tutorial Android. O tutorial notepad parece caber a conta: http://developer.android.com /guide/tutorials/notepad/index.html
Outras dicas
Você pode usar métodos Cursor
do get*
para recuperar valores a partir do resultado:
long id = cursor.getLong(cursor.getColumnIndex("_id"));
long title = cursor.getString(cursor.getColumnIndex("title"));
...
Melhor prática é, obviamente, a constantes de uso (muitas vezes fornecidos pelo ContentProviders) em vez de chamadas para getColumnIndex
com cordas hardcoded.
Você pode usar esse mecanismo.
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();
}