Android短信数据库读取问题
今天将短信软件在真机上测试,一直装不上,在模拟器上都是好的。一直报NullPointerException空指针异常。后来又单独写了个测试程序,经过不断尝试发现是短信数据库中的"address"字段的问题。由于不能在命令中查看字段类型,所以我用一个小工具SQLite Developer来查看字段类型,使用SQLite Developer查看得"address"字段的数据类型是TEXT,于是我就使用Cursor.getString()来获取数据,结果就是不断的报错。唉!后来没办法,把所有的类型都是了一遍,结果使用Cursor.getInt()时成功运行通过。纠结,其他的如"body"字段,都是用getString()的啊!
有图为证:
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. 怎么会遇到这样的问题,倒霉吗?
相关推荐
lbyd0 2020-11-17
sushuanglei 2020-11-12
腾讯soso团队 2020-11-06
gaobudong 2020-11-04
yangkang 2020-11-09
85477104 2020-11-17
KANSYOUKYOU 2020-11-16
wushengyong 2020-10-28
lizhengjava 2020-11-13
星月情缘 2020-11-13
huangxiaoyun00 2020-11-13
luyong0 2020-11-08
Apsaravod 2020-11-05
PeterChangyb 2020-11-05
wwwjun 2020-11-02
gyunwh 2020-11-02
EchoYY 2020-10-31
dingyahui 2020-10-30