문제

응용 프로그램을 작성하고 문제가 있습니다 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

다른 팁

당신은 사용할 수 있습니다 Cursor'에스 get* 결과에서 값을 검색하는 방법 :

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

더 나은 연습은 분명히 호출 대신 상수 (종종 콘텐츠 제공 업체가 제공하는)를 사용하는 것입니다. getColumnIndex 하드 코드 스트링.

이 메커니즘을 사용할 수 있습니다.

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