Android 系统数据库

1.负责存放呼叫记录的内容提供者源码在 ContactsProvider 项目下:(http://blog.csdn.net/flying_vip_521/article/details/7258805)

       源码路径:

       com/android/providers/contacts/CallLogProvider.java

      

       使用到的数据库在:

       /data/data/com.android.providers.contacts/databases/contacts2.db

       表名:calls

      

       呼叫记录有三种类型:

       来电:CallLog.Calls.INCOMING_TYPE (常量值:1)

       已拨:CallLog.Calls.OUTGOING_TYPE(常量值:2)

       未接:CallLog.Calls.MISSED_TYPE(常量值:3)

      

       查看源码中的声明:

              <provider android:name="CallLogProvider"

                   android:authorities="call_log"

                   android:syncable="false" android:multiprocess="false"

                   android:readPermission="android.permission.READ_CONTACTS"

                   android:writePermission="android.permission.WRITE_CONTACTS">

               </provider>

3.需要声明的权限

       <uses-permission android:name="android.permission.READ_CONTACTS" />

       <uses-permission android:name="android.permission.WRITE_CONTACTS" />

 

4. 系统的通话记录,是通过 ContentProvider 来对外共享的

 

5. Uri

       CallLog.Calls.CONTENT_URI : 等价于:Uri.parse("content://call_log/calls");

6. 查询出所有记录

       ContentResolver resolver = getContentResolver();

       resolver.query(CallLog.Calls.CONTENT_URI, null, null, new String[]{"15101689022"}, null);

      

7. 查询某一个联系人的所有记录(按电话号码)

       resolver.query(CallLog.Calls.CONTENT_URI, null, "number=?", new String[]{"15101689022"}, null);

 

8. 查询某一个联系人的所有未接电话记录(按电话号码)

       resolver.query(CallLog.Calls.CONTENT_URI, null, "number=? and type=3", new String[]{"15101689022"}, null);

8. 删除某联系人最近的一次来电

[html]  view plain  copy
  1. /* 本代码因为在 Activity 中,所以可以直接调用 getContentResolver()。这个方法实际上是 Context 中定义的。 */  
  2. ContentResolver resolver = getContentResolver();  
  3. /* 这里涉及到内容提供者的知识,其实这里是直接在操作 Android 的数据库,十分痛苦 */  
  4. Cursor cursor = resolver.query(CallLog.Calls.CONTENT_URI, new String[]{"_id"}, "number=? and (type=1 or type=3)",  new String[]{"15101689022"},  "_id desc limit 1");  
  5. if(cursor.moveToFirst()) {  
  6.     int id = cursor.getInt(0);  
  7.     resolver.delete(CallLog.Calls.CONTENT_URI, "_id=?", new String[] {id + ""});  
  8. }  
2.获取Android内部通话记录(http://my.oschina.net/yyplayer/blog/130077)
Cursor cursor = context.getContentResolver().query(CallLog.Calls.CONTENT_URI, null, null, null, null);
if(cursor.moveToFirst()){
    do{
        CallsLog calls =new CallsLog();
        //号码                                                                                             
        String number = cursor.getString(cursor.getColumnIndex(Calls.NUMBER));
        //呼叫类型                                                                                           
        String type;
        switch (Integer.parseInt(cursor.getString(cursor.getColumnIndex(Calls.TYPE)))) {
            case Calls.INCOMING_TYPE:
                type = "呼入";
                break;
            case Calls.OUTGOING_TYPE:
                type = "呼出";
                break;
            case Calls.MISSED_TYPE:
                type = "未接";
                break;
            default:
                type = "挂断";//应该是挂断.根据我手机类型判断出的                                                              
                break;
        }
        SimpleDateFormat sfd = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        Date date = new Date(Long.parseLong(cursor.getString(cursor.getColumnIndexOrThrow(Calls.DATE))));
        //呼叫时间                                                                                           
        String time = sfd.format(date);
        //联系人                                                                                            
        String name = cursor.getString(cursor.getColumnIndexOrThrow(Calls.CACHED_NAME));
        //通话时间,单位:s                                                                                      
        String duration = cursor.getString(cursor.getColumnIndexOrThrow(Calls.DURATION));

    }while(cursor.moveToNext());

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值