`
jandroid
  • 浏览: 1896134 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Android中的短信

阅读更多

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

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

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

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

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

获取会话信息的URI

Java代码
  1. public   static   final  Uri MMSSMS_FULL_CONVERSATION_URI = Uri.parse( "content://mms-sms/conversations" );  
  2. public   static   final  Uri CONVERSATION_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. String recipIDs = cursor.getString(RECIPIENT_IDS);  
  5. String snippet = 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); 
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics