7

次のステートメントcursor.moveToNext()は常に誤りです。ループが1回実行されることを期待しています。クエリが実際にデータを返すことをテストしました。

誰かが問題が何であるか知っていますか?

    String query ="SELECT(SELECT COUNT(*) FROM Table1) as count1, (SELECT COUNT(*) FROM Table2) as count2;";

    Cursor mCursor = mDb.rawQuery(query, null);

    if (mCursor != null) {
        mCursor.moveToFirst();
    }

    while (cursor.moveToNext()) {   //<---------------return false here???
        String result_0=cursor.getString(0);
    }
4

2 に答える 2

4

問題が解決したことは承知していますが、発生した問題のウォークスルーを以下に示します。

Cursor mCursor = mDb.rawQuery(query, null);

// At this point mCursor is positioned at just before the first record.

if (mCursor != null) {
    mCursor.moveToFirst();
    // mCursor is now pointing at the first (and only) record
}

while (mCursor.moveToNext()) {
    String result_0=cursor.getString(0);
}

// The loop above was skipped because `.moveToNext()` caused mCursor
// to move past the last record.

したがって、単一のレコードのみが必要な場合は、mCursor.moveToFirst() ORのいずれかのみが必要mCursor.moveToNext()です。

于 2013-03-07T02:26:39.943 に答える
4

この方法でカーソルを反復できます。

    if(moveCursor.moveToFirst()){
        do{
            //your code

        }while(moveCursor.moveToNext());
    }               
于 2013-03-07T04:34:43.070 に答える