Vedo spesso il codice che comporta l'iterazione sul risultato di una query del database, l'esecuzione di operazioni con ciascuna riga e il passaggio alla riga successiva. Esempi tipici sono i seguenti.
Cursor cursor = db.rawQuery(...);
cursor.moveToFirst();
while (cursor.isAfterLast() == false)
{
...
cursor.moveToNext();
}
Cursor cursor = db.rawQuery(...);
for (boolean hasItem = cursor.moveToFirst();
hasItem;
hasItem = cursor.moveToNext()) {
...
}
Cursor cursor = db.rawQuery(...);
if (cursor.moveToFirst()) {
do {
...
} while (cursor.moveToNext());
}
Tutto questo mi sembra eccessivamente prolisso, ognuno con più chiamate ai Cursor
metodi. Sicuramente ci deve essere un modo più ordinato?