好久没写了,今天被一个问题给搞得头疼,就像是发烧的征兆,实质是头疼脑大的啦~\(≧▽≦)/,好了,不多说,今天遇到的问题,都是不细心!
问题: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这里查看数据库的路径.
更改后,运行,哈哈,数据全部读出来了。开心~\(≧▽≦)/~啦啦啦