Cursor mCursor = db.rawQuery(sql,null);一直为空!!报错!!建议:勿急勿躁,一步一步重新执行,最终发觉问题

来源:互联网 发布:淘宝 少女服饰 编辑:程序博客网 时间:2024/06/06 01:21

好久没写了,今天被一个问题给搞得头疼,就像是发烧的征兆,实质是头疼脑大的啦~\(≧▽≦)/,好了,不多说,今天遇到的问题,都是不细心!

问题:Cursor mCursor = db.rawQuery(sql,null);一直为空!!报错!!

网上查找了好久,也尝试了网上很多的方法,比如:

1、就是说查询语句中,有null ..... -------------------看了下数据库,没有null,sql语句中也没有  ---------- 方法不适合;

2、添加 if(! cursor.moveToFirst())的判断----------------执行了下---------方法不合适;

3、Cursor c = db.rawQuery("SELECT * FROM doorbell WHERE url = ?",new String[]{urlname});------方法中么用不到定义----方法不合适;

4、if(cursor.getCount > 0)添加判断--------------不合适;

 

最终实在受不了了,打断点,看看到底啥回事(路过大神不要说我,我是菜鸟,才想起来打断点,我错啦!),顺便教一下不会打断点的童鞋,会打的就麻利点走开,不要笑话我,哼╭(╯^╰)╮

打断点开始:

第一步:进入DDMS ---找到甲壳虫-----对着你要运行的launcher打上甲壳虫标记

 

 

 

第二步:在你报错的地方打上断点。我的是这句报错,看了下debug,提示 db = null.

 

 

第三部:运行launcher,程序自动进入debug,可查看具体数据信息,如我的,哼哼,一直提示db = null,原来mDatabase一直为空。

 

 

第四步:进入db.class中,查找为空的原因,终于找到了:PACKAGE_NAME = "com.jsbd.illegallyquery.database"; 包名有问题

可在data/data/com.xxx.xxx/xxx.db这里查看数据库的路径.

 

更改后,运行,哈哈,数据全部读出来了。开心~\(≧▽≦)/~啦啦啦

1 0
原创粉丝点击