Android中的短信并没有正式的content provider可用,在官方文档中没有提供定义。不过依然可以自己定义好URI,然后查询出短信内容。例如conetent://sms则是所有短信所在的path。

要将短信按会话分类,原先我是查询出所有短信后,然后再按照thread_id分类。系统自带的短信程序包含一个会话显示界面,每个条目包含:联 系人、短信数量、第一条短信等内容。当我的程序处理的短信较多时,一次查询出所有的短信就变得很慢。(如果再加上为每个会话查询联系人信息,则会更慢)

看了系统短信的代码,发现它可以只查询出会话的信息,而不用查询出所有短信内容。因为部分代码没找到,一直不知道它是怎么做到的。看了telphony provider的代码后,才知晓一二。

实际上,短信数据库中(mmssms.db)并没有一个表存储会话信息的。系统提供的content provider中,实际上是支持直接查询会话信息的。 只不过,其实现方式,不是通过一个现成的表,而是通过SQL语句,从多个表里取数据完成的。关于这个实现方式,在这个帖子中 也有所提及。

实现方式就不深究了,毕竟我对SQL查询不太熟。放出直接的使用方法:

获取会话信息的URI

Java代码
  1. public static final UriMMSSMS_FULL_CONVERSATION_URI=Uri.parse( "content://mms-sms/conversations" );
  2. public static final UriCONVERSATION_URI=MMSSMS_FULL_CONVERSATION_URI.buildUpon().
  3. appendQueryParameter("simple" , "true" ).build();
public static final Uri MMSSMS_FULL_CONVERSATION_URI = Uri.parse("content://mms-sms/conversations");public static final Uri CONVERSATION_URI = MMSSMS_FULL_CONVERSATION_URI.buildUpon().appendQueryParameter("simple", "true").build();



通过指定simple=true,则可以获取出一个大概的会话数据,包含以下列:

Java代码
  1. private static final int ID= 0 ;
  2. private static final int DATE= 1 ;
  3. private static final int MESSAGE_COUNT= 2 ;
  4. private static final int RECIPIENT_IDS= 3 ;
  5. private static final int SNIPPET= 4 ;
  6. private static final int SNIPPET_CS= 5 ;
  7. private static final int READ= 6 ;
  8. private static final int TYPE= 7 ;
  9. private static final int ERROR= 8 ;
  10. private static final int HAS_ATTACHMENT= 9 ;
    private static final int ID             = 0;    private static final int DATE           = 1;    private static final int MESSAGE_COUNT  = 2;    private static final int RECIPIENT_IDS  = 3;    private static final int SNIPPET        = 4;    private static final int SNIPPET_CS     = 5;    private static final int READ           = 6;    private static final int TYPE           = 7;    private static final int ERROR          = 8;    private static final int HAS_ATTACHMENT = 9;



列名则为:

Java代码
  1. private static final String[]ALL_THREADS_PROJECTION={
  2. "_id" , "date" , "message_count" , "recipient_ids" ,
  3. "snippet" , "snippet_cs" , "read" , "error" , "has_attachment"
  4. };
    private static final String[] ALL_THREADS_PROJECTION = {        "_id", "date", "message_count", "recipient_ids",        "snippet", "snippet_cs", "read", "error", "has_attachment"    };



其中:
1、message_count为该会话的消息数量;
2、recipient_ids为联系人ID,这个ID不是联系人表中的_id,而是指向表 canonical_addresses 里的id,canonical_addresses这个表同样位于mmssms.db,它映射了recipient_ids到一个电话号码,也就是说,最 终获取联系人信息,还是得通过电话号码;
3、snippet为最后收到/发送的短信;

每个数据的类型嘛,大致为:

Java代码
  1. long id=cursor.getLong(ID);
  2. long date=cursor.getLong(DATE);
  3. long msgCount=cursor.getLong(MESSAGE_COUNT);
  4. StringrecipIDs=cursor.getString(RECIPIENT_IDS);
  5. Stringsnippet=cursor.getString(SNIPPET);
  6. long snippetCS=cursor.getLong(SNIPPET_CS);
  7. long read=cursor.getLong(READ);
  8. long type=cursor.getLong(TYPE);
  9. long error=cursor.getLong(ERROR);
  10. long hasAttach=cursor.getLong(HAS_ATTACHMENT);

更多相关文章

  1. 没有一行代码,「2020 新冠肺炎记忆」这个项目却登上了 GitHub 中
  2. 美军方拨款 提升Android系统安全性能
  3. android,闹钟定时功能,实现过程
  4. Android第一行代码踩坑qwq
  5. App模块化及工程扩展----- android
  6. Android(安卓)实现对图片 Exif 的修改(Android(安卓)自带的方法)
  7. android 模拟器和电脑服务器端用socket通讯
  8. Android(安卓)静默安装和智能安装的实现方法
  9. Android(安卓)MVP模式实践

随机推荐

  1. Android 提供的一系列辅助系统开发工具
  2. Android(安卓)获取验证码倒计时实现
  3. Android本地数据存储之SQLite
  4. android UI学习书籍
  5. [置顶] Android(安卓)IPC 通讯机制源码分
  6. 我的android 第10天 - pull解析Xml文档
  7. 【Android开发基础】应用界面主题Theme使
  8. Android的ContextMenu(上下文菜单)知识链
  9. 导入现有Android工程
  10. android:初级 [Android] Eclipse Android