2009-05-24 10 views
27

Estoy creando una aplicación y tengo problemas con Cursor. Tengo una SQLiteDatabase que me devuelve un Cursor cuando trato de obtener los valores de esta función:Obtenga el valor del campo con un 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; 

} 

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?

Respuesta

80

Creo que puede olvidarse de verificar null.

cheque en lugar si hay datos y luego acceder a las columnas utilizando 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 androide. El tutorial del bloc de notas parece ajustarse a la factura: http://developer.android.com/guide/tutorials/notepad/index.html

+2

Gracias por su ayuda. Ahora funciona. Olvidé cada acceso para cerrar el cursor ... –

+0

tu respuesta también me ayuda ... gracias ... sigue respondiendo ... +1 por ti. – Siten

+1

cada vez que tengo este problema, vuelvo aquí y me doy cuenta de que olvidé cursor.moveToFirst(). ¡Gracias! – user1549672

15

Usted puede utilizar métodos get* la Cursor 's para recuperar los valores del resultado:

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

mejor práctica es, obviamente, para usar constantes (a menudo proporcionados por ContentProviders) en lugar de llamadas a getColumnIndex con las secuencias codificadas.

+0

con la parte: int a = mOptionDb.fetchOption (0) .getColumnIndex ("título"); Obtengo "1". Pero con mOptionDb.fetchOption (0) .getString (a); I obtener errores: ERROR/Android Runtime (628): controlador no detectada: hilo principal de salir debido a uncaught excepción ERROR/Android Runtime (628): android.database.CursorIndexOutOfBoundsException: Índice 0 solicitó, con un tamaño de 0 Es como si hubiera no es datas ?! –

6

Puede usar 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();   
} 
Cuestiones relacionadas