在smsmms.db中有个sms表,里面含有_id、thread_id、address、person、date、protocol、read、status、type、reply_path_present、subject、body、service_center、locked这些属性。这个表存有收发信息和草稿信息,但是草稿信息的发送地址即address属性在这个表中却为空(事实是草稿信息的address没有保存在sms这个表中,其他属性值正常),只能在canonical_addresses这个表中找到草稿信息的address,但是canonical_addresses这个表中只有两个属性值即_id和address,要找到草稿信息的address,先得知道_id,这个canonical_addresses表中的_id对应了threads表中的recipient_ids属性,而threads表中的_id对应了sms表中的thread_id,现在问题出来了,没有查找threads表的接口,另外两个表都有相应的接口,可以根据sms表中的thread_id找到threads表中的_id,但是不能根据threads表中的_id找到这个表中的recipient_ids,从而也不能再根据已经得到的recipient_ids值去canonical_addresses表中找到相应的address。(不知道我的问题描述清楚没,各位大侠求解!)

解决方案 »

  1.   

    建议使用android提供的联系人操作方法,不要自己去操作系统的联系人数据库。
      

  2.   

    问题已经解决!感谢关注!读取threads表的间接方法getContentResolver().query(Uri.parse("content://sms/"), new String[]{"* from threads --"}, null, null, null);
    来源:http://topic.csdn.net/u/20100804/12/67607078-e17c-4afc-8228-9dcf9a366b03.html