Obtener el valor del campo con un cursor
-
05-09-2019 - |
Pregunta
Estoy creando una aplicación y no tengo problemas con Cursor
. Tengo una SQLiteDatabase
que me devuelve un Cursor
cuando trato de obtener los valores de esta función:
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;
}
No sé cómo obtener el valor del campo en el Cursor
. Si lo hago de esta manera:
String a = mOptionDb.fetchOption(0).getColumnName(0).toString();
String b = mOptionDb.fetchOption(0).getColumnName(1).toString();
String c = mOptionDb.fetchOption(0).getColumnName(2).toString();
Sólo obtener el nombre de las columnas (_id, title, body
) pero no los valores. ¿Alguna sugerencia sobre cómo lograr esto?
Solución
Creo que se puede olvidarse de la comprobación de nulo.
En lugar comprobar si hay datos y acceder a las columnas usando el 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
También podría tener sentido para leer un tutorial de Android. El tutorial libreta parece ajustarse a la ley: http://developer.android.com /guide/tutorials/notepad/index.html
Otros consejos
Puede utilizar métodos Cursor
del get*
a recuperar valores del resultado:
long id = cursor.getLong(cursor.getColumnIndex("_id"));
long title = cursor.getString(cursor.getColumnIndex("title"));
...
Una mejor práctica es, obviamente, para usar constantes (a menudo proporcionados por ContentProviders) en lugar de llamadas a getColumnIndex
con las secuencias codificadas.
Puede utilizar este 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();
}