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

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

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

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

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

  获取会话信息的URI

  Java代码

  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();

  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代码

  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代码

  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代码

  long id = cursor.getLong(ID);

  long date = cursor.getLong(DATE);

  long msgCount = cursor.getLong(MESSAGE_COUNT);

  String recipIDs = cursor.getString(RECIPIENT_IDS);

  String snippet = cursor.getString(SNIPPET);

  long snippetCS = cursor.getLong(SNIPPET_CS);

  long read = cursor.getLong(READ);

  long type = cursor.getLong(TYPE);

  long error = cursor.getLong(ERROR);

  long hasAttach = cursor.getLong(HAS_ATTACHMENT);

  long id = cursor.getLong(ID);

  long date = cursor.getLong(DATE);

  long msgCount = cursor.getLong(MESSAGE_COUNT);

  String recipIDs = cursor.getString(RECIPIENT_IDS);

  String snippet = cursor.getString(SNIPPET);

  long snippetCS = cursor.getLong(SNIPPET_CS);

  long read = cursor.getLong(READ);

  long type = cursor.getLong(TYPE);

  long error = cursor.getLong(ERROR);

  long hasAttach = cursor.getLong(HAS_ATTACHMENT);

更多相关文章

  1. Android(安卓)Gesture手势识别使用实例
  2. Android(安卓)camera 架构的解析2
  3. Android进阶(十)Android(安卓)发邮件
  4. Android应用程序绑定服务(bindService)的过程源代码分析(1)
  5. Android调用so文件(C代码库)方法详解
  6. 【Android学习】Day 1
  7. Android(安卓)操作系统的设计与实现--框架
  8. Android(安卓)Gallery3D源码分析(一)
  9. Android(安卓)TV HDMI开发

随机推荐

  1. 敏捷这么久,你知道如何开敏捷发布火车吗?
  2. 11:VMware Horizon View 8.0-部署配置UAG网
  3. 2021年Phpstorm激活码已送到 ,请注意查收
  4. 容器云平台No.3~kubernetes简单使用
  5. 【DevOps进行时】基于iOS平台的集中构建
  6. 容器云平台No.4~kubernetes 服务暴露之In
  7. Linux系统安装
  8. 每天万次触发的持续交付工具链是这样炼成
  9. 容器云平台No.6~企业级分布式存储Ceph~v1
  10. 使用无服务器式的 Jenkins X:探索Prow,Jenk