データベースクエリの結果を繰り返し処理し、各行で何かを実行してから、次の行に移動するコードをよく目にします。典型的な例は次のとおりです。
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());
}
これらはすべて、私には非常に長い時間がかかり、それぞれがCursor
メソッドへの複数の呼び出しを持っているように見えます。確かにもっときちんとした方法があるに違いありませんか?