33

アプリケーションを作成していますが、Cursor. この関数で値を取得しようとするとSQLiteDatabase、 a を返す があります。Cursor

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;

}

のフィールドの値を取得する方法がわかりませんCursor。私がそうするなら:

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

列の名前 ( _id, title, body) のみを取得し、値は取得しません。これを達成する方法について何か提案はありますか?

4

3 に答える 3

94

nullのチェックを忘れてもいいと思います。

代わりに、データがあるかどうかを確認してから、カーソルを使用して列にアクセスします。

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

Android のチュートリアルを読むことも意味があるかもしれません。メモ帳のチュートリアルは、法案に合っているようです: http://developer.android.com/guide/tutorials/notepad/index.html

于 2009-05-24T14:13:54.843 に答える
17

Cursorget*メソッドを使用して、結果から値を取得できます。

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

ハードコーディングされた文字列を使用して を呼び出す代わりに、定数 (多くの場合 ContentProviders によって提供される) を使用することをお勧めgetColumnIndexします。

于 2009-05-24T09:44:43.887 に答える
7

このメカニズムを使用できます。

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();        
}
于 2012-09-26T05:31:06.300 に答える