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

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

问题: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这里查看数据库的路径.

 

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

  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package com.JingTing.DBhelperClass; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; public class DBHelper extends SQLiteOpenHelper { public DBHelper(Context context) { super(context, "data.db", null, 1); } @Override public void onCreate(SQLiteDatabase db) { String createnotestable="create table datas (_id integer primary key autoincrement,ItemName text,Money float,time datatime)"; db.execSQL(createnotestable); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL("drop table datas if exits"); onCreate(db); } public Cursor ExitsData() { SQLiteDatabase db = getReadableDatabase(); return db.rawQuery("select * from datas",null); } public Cursor SumMoney() { SQLiteDatabase db = getReadableDatabase(); return db.rawQuery("select SUM(Money) as SumAll from datas",null); } public Cursor ExitsIncome() { SQLiteDatabase db = getReadableDatabase(); return db.rawQuery("select * from datas where Money>0",null); } public Cursor SumInCome() { SQLiteDatabase db = getReadableDatabase(); return db.rawQuery("select SUM(Money) as SumInCome from datas where Money>0",null); } public Cursor ExitsExpenditure() { SQLiteDatabase db = getReadableDatabase(); return db.rawQuery("select * from datas where Money<0",null); } public Cursor SumExpenditure() { SQLiteDatabase db = getReadableDatabase(); return db.rawQuery("select SUM(Money) as SumExpenditure from datas where Money<0",null); } public Cursor SelectAllItem() { SQLiteDatabase db = getReadableDatabase(); return db.rawQuery("select * from datas order by time desc",null); } public long insertData(String ItemName,int Money,String time) { SQLiteDatabase DB=getWritableDatabase(); ContentValues values=new ContentValues(); values.put("ItemName", ItemName); values.put("Money", Money); values.put("time", time); return DB.insert("datas", null, values); } }

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值