早期学习android的时候遇到的一个很蠢的问题,忘记将Cursor先moveToFirst然后在遍历读取数据了。
下面的代码会返回错误
User u = null;
SQLiteDatabase db = dbHelper.getReadableDatabase();
Cursor cursor = db.rawQuery("select * from user where id = ?", new String[] { id.toString() });
Integer uid = cursor.getInt(cursor.getColumnIndex("id"));
String uname = cursor.getString(cursor.getColumnIndex("name"));
float uamount = cursor.getFloat(cursor.getColumnIndex("amount"));
u = new User(uid, uname, uamount);cursor.close();
正确的用法
User u = null;
SQLiteDatabase db = dbHelper.getReadableDatabase();
Cursor cursor = db.rawQuery("select * from user where id = ?", new String[] { id.toString() });
if (cursor.moveToFirst())
{
Integer uid = cursor.getInt(cursor.getColumnIndex("id"));
String uname = cursor.getString(cursor.getColumnIndex("name"));
float uamount = cursor.getFloat(cursor.getColumnIndex("amount"));
u = new User(uid, uname, uamount);
}
cursor.close();
另外,不能将Cursor作为值传递到数据集合然后再获取,这样是不行的,访问数据最好的办法还是采用循环来完成。
本文介绍了在Android开发中使用SQLite进行数据查询时,如何正确地利用Cursor对象遍历并读取数据的方法。强调了必须先调用moveToFirst()确保定位到第一行数据的重要性,并给出了一段错误示例与正确示例的对比。
2884

被折叠的 条评论
为什么被折叠?



