質問

私は、アプリケーションを作成していると私はCursorに問題があります。私はこの機能を使用して値を取得しようとすると、私は私にSQLiteDatabaseを返す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)ではなく、値の名前を取得します。これを実現する方法上の任意の提案?

役に立ちましたか?

解決

私は、あなたが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する

他のヒント

あなたは結果から値を取得するためにCursorget*メソッドを使用することができます:

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

より良い練習がハードコーディングされた文字列でgetColumnIndexする定数(しばしばContentProvidersによって提供される)の代わりに、コールを使用することは明らかである。

あなたはこのメカニズムを使用することができます。

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();        
}
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top