Android短信数据库读取问题

    今天将短信软件在真机上测试,一直装不上,在模拟器上都是好的。一直报NullPointerException空指针异常。后来又单独写了个测试程序,经过不断尝试发现是短信数据库中的"address"字段的问题。由于不能在命令中查看字段类型,所以我用一个小工具SQLite Developer来查看字段类型,使用SQLite Developer查看得"address"字段的数据类型是TEXT,于是我就使用Cursor.getString()来获取数据,结果就是不断的报错。唉!后来没办法,把所有的类型都是了一遍,结果使用Cursor.getInt()时成功运行通过。纠结,其他的如"body"字段,都是用getString()的啊!

有图为证:

SQLite Developer下的sms数据表结构

				Cursor myCursor = managedQuery(Uri.parse("content://sms")
						, new String[]{"_id","thread_id","address","date","body"},null,null,"thread_id asc");
				if(myCursor.moveToFirst()) {
					do {
						String body = myCursor.getString(myCursor.getColumnIndex("body"));//使用getString()运行通过
						int address = myCursor.getInt(myCursor.getColumnIndex("address"));//使用getInt()运行通过
						System.out.println(address);
					} while(myCursor.moveToNext());
				}

 总结:1. 真机和模拟器是不一样的,至少在数据库数据类型的匹配要求上是不同的。

          2. 怎么会遇到这样的问题,倒霉吗?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值