zoukankan      html  css  js  c++  java
  • Android android.database.CursorIndexOutOfBoundsException:Index -1 requested, with a size of 1

    Android数据库处理使用cursor时,游标不是放在为0的下标,而是放在为-1的下标处开始的。

    也就是说返回给cursor查询结果时,不能够马上从cursor中提取值。

    下面的代码会返回错误

    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();  
  • 相关阅读:
    KMP算法
    214. Shortest Palindrome
    5. Longest Palindromic Substring
    266. Palindrome Permutation
    Oracle 在not in中使用null的问题
    Oracle SQL性能优化技巧大总结
    EBS trace分析
    从SEQUENCE跳号说起
    使用WebService与Oracle EBS进行集成
    EBS xml publisher中文乱码
  • 原文地址:https://www.cnblogs.com/zhujiabin/p/6393123.html
Copyright © 2011-2022 走看看