Ottenere il valore del campo con un cursore
-
05-09-2019 - |
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?
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();
}