Android Sqlite数据查询遇到android.database.CursorIndexOutOfBoundsException: Index -1 requested问题

(个人经验,仅供参考,错误之处,敬请谅解)

    个人遇到这个问题不止一次,所以记录下来,原因很简单,返回的cursor结果集的游标默认在-1,需要移到0(开始读取位置)

详细报错

Process: cn.cslg.test4, PID: 5644
android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 1
at android.database.AbstractCursor.checkPosition(AbstractCursor.java:468)
at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:136)
at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:50)
at cn.cslg.test4.MainActivity 1. o n C l i c k ( M a i n A c t i v i t y . j a v a : 49 ) a t a n d r o i d . v i e w . V i e w . p e r f o r m C l i c k ( V i e w . j a v a : 6294 ) a t a n d r o i d . v i e w . V i e w 1.onClick(MainActivity.java:49) at android.view.View.performClick(View.java:6294) at android.view.View 1.onClick(MainActivity.java:49)atandroid.view.View.performClick(View.java:6294)atandroid.view.ViewPerformClick.run(View.java:24770)
at android.os.Handler.handleCallback(Handler.java:790)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:164)
at android.app.ActivityThread.main(ActivityThread.java:6494)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)

解决方案

if(cursor.moveToFirst()) {
   ......       //cursor读取数据
}
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值