使用Cursor获取字段值

Mic*_*aël 31 java android android-sqlite

我正在创建一个应用程序,我遇到了问题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;

}
Run Code Online (Sandbox Code Playgroud)

我不知道如何获得该领域的价值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();
Run Code Online (Sandbox Code Playgroud)

我只获取列(_id, title, body)的名称,但不获取值.有关如何实现这一目标的任何建议?

Mar*_*amp 91

我想你可以忘记检查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
Run Code Online (Sandbox Code Playgroud)

阅读android教程也许有意义.记事本教程似乎符合要求:http://developer.android.com/guide/tutorials/notepad/index.html

  • 谢谢您的帮助.现在它有效.我忘了每次关闭光标的访问权限...... (2认同)

Jos*_*ger 15

您可以使用Cursorget*方法从结果中检索值:

long id = cursor.getLong(cursor.getColumnIndex("_id"));
long title = cursor.getString(cursor.getColumnIndex("title"));
...
Run Code Online (Sandbox Code Playgroud)

更好的做法显然是使用常量(通常由ContentProviders提供)而不是getColumnIndex使用硬编码字符串调用.


小智 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();        
}
Run Code Online (Sandbox Code Playgroud)