データベースクエリの結果を反復処理し、各行で何かを実行してから、次の行に移動するコードをよく目にします。代表的な例を以下に示します。
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
メソッドへの複数の呼び出しがあります。きっとすてきな方法があるに違いない?