题
我创建的应用程序和我有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
),但不值的名称。就如何实现这一目标的任何建议吗?
解决方案
我想你,可检查空忘记。
相反检查是否有数据,然后使用光标访问各列:
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"));
...
更好的做法是明显,而不是使用呼叫常数(通常由ContentProviders提供)与硬编码的字符串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();
}
不隶属于 StackOverflow