Question

Je crée une application et j'ai des problèmes avec Cursor. J'ai un SQLiteDatabase qui me renvoie un Cursor lorsque je tente de récupérer les valeurs avec cette fonction:

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;

}

Je ne sais pas comment obtenir la valeur du champ dans la Cursor. Si je fais ça comme ceci:

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

Je ne pouvez utiliser que le nom des colonnes (_id, title, body), mais pas les valeurs. Toutes les suggestions sur la façon d'y parvenir?

Était-ce utile?

La solution

Je pense que vous pouvez oublier la vérification de null.

vérifier s'il y a lieu de données et accéder aux colonnes à l'aide du curseur:

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

Il pourrait également judicieux de lire un tutoriel Android. Le tutoriel bloc-notes semble correspondre à la facture: http://developer.android.com /guide/tutorials/notepad/index.html

Autres conseils

Vous pouvez utiliser les méthodes de Cursor de get* pour récupérer les valeurs du résultat:

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

Une meilleure pratique est évidemment d'utiliser des constantes (souvent fournies par ContentProviders) au lieu des appels à getColumnIndex avec chaînes codées en dur.

Vous pouvez utiliser ce mécanisme.

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();        
}
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top