Domanda

Sto creando un'applicazione e non ho problemi con Cursor. Ho un SQLiteDatabase che mi restituisce un Cursor quando cerco di recuperare i valori con questa funzione:

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;

}

Non so come ottenere il valore del campo nel Cursor. Se lo faccio in questo modo:

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

ottengo solo il nome delle colonne (_id, title, body), ma non i valori. Qualche suggerimento su come raggiungere questo obiettivo?

È stato utile?

Soluzione

Penso che si può dimenticare il controllo di nulla.

controllare Invece se sono presenti dati e quindi accedere alle colonne utilizzando il cursore:

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

Si potrebbe anche avere un senso di leggere un tutorial Android. Il tutorial notepad sembra adattarsi il disegno di legge: http://developer.android.com /guide/tutorials/notepad/index.html

Altri suggerimenti

È possibile utilizzare i metodi Cursor del get* per recuperare i valori del risultato:

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

Una migliore pratica è ovviamente quello di utilizzare le costanti (spesso forniti da ContentProviders) invece di chiamate verso getColumnIndex con le stringhe hardcoded.

È possibile utilizzare questo meccanismo.

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();        
}
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top