首先,我们需要知道的两个Uri:

1、Uri uri = Uri.parse("content://com.android.contacts/raw_contacts");//查到data表中raw_contact_id

2、Uri uri1 = Uri.parse("content://com.android.contacts/data");

想取数据库里面的信息,就必须要知道表的结构我们看一下view_data表:

我们只需要关心下面三列数据:

从表中我们可以看出,Google将联系人信息放在了一列中,也就是data1列,根据raw_contact_id来区分是否为同一个人的信息,根据mimetype区分联系人信息中的name、phone、email,所以首先我们要获得的是raw_contact_id,但是view_data表中的raw_contact_id是重复的。

下面我们再来看一张表raw_contacts:

从这张表中,我们可以获得联系人的raw_contact_id,也就可以获得联系人的个数,然后通过raw_contact_id获取每个联系人。

表的结构了解了,下面我们来看代码:

     public void readContacts(){
         String name = null;
         String phone= null;
         String eMail= null;
         Uri uri = Uri.parse("content://com.android.contacts/raw_contacts");
         Uri uri1 = Uri.parse("content://com.android.contacts/data");
         Cursor cursor = getContentResolver().query(uri,new String[]{"contact_id"},null,null,null);
         while (cursor.moveToNext()){
             String contacts_id = cursor.getString(0);
             //System.out.println("contact_id :"+contacts_id);

             if (contacts_id!=null){
                 /**
                  * projection  第二个参数,要查询的列,为null则是查询所有的列
                  * selection    第三个参数,根据什么条件查询
                  * selectionArgs    第四个参数,根据什么查的参数
                  *
                  */
                 Cursor cursor1 = getContentResolver().query(uri1,new String[]{"data1","mimetype"},"raw_contact_id=?",new String[]{contacts_id},null);
                 while (cursor1.moveToNext()){
                     String data1 = cursor1.getString(0);
                     String mimetype = cursor1.getString(1);
                     //System.out.println("data1:"+data1+"--"+"mimetype:"+mimetype);
                     if (mimetype.equals("vnd.android.cursor.item/name")){
                         name = data1;
                     }else if (mimetype.equals("vnd.android.cursor.item/phone_v2")){
                         phone = data1;
                     }else if (mimetype.equals("vnd.android.cursor.item/email_v2")){
                         eMail = data1;
                     }

                 }
                 System.out.println("name:"+name+"- phone:"+phone+" -email:"+eMail);
             }
         }
     }

记得加权限:

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

从代码中,我们可以看的很清楚,先获取raw_contact_id,然后通过他,获取data1和mimetype,然后通过mimetype知道data1中的数据是name、phone或者email。

ps:其实解析data表就是解析view_data

下面是插入联系人:
看代码:
    public void insertContacts(){
        Uri uri = Uri.parse("content://com.android.contacts/raw_contacts");
        Uri uri1 = Uri.parse("content://com.android.contacts/data");
        Cursor cursor = getContentResolver().query(uri,null,null,null,null);
        int count = cursor.getCount();
        int count_id = count+1;

        ContentValues values = new ContentValues();
        values.put("contact_id",count_id);
        getContentResolver().insert(uri,values);
        ContentValues contactValue = new ContentValues();

        contactValue.put("data1","张三");
        contactValue.put("raw_contact_id",count_id);
        contactValue.put("mimetype","vnd.android.cursor.item/name");
        getContentResolver().insert(uri1,contactValue);
        contactValue.clear();//插完之后记得clear

        contactValue.put("data1","133333333");
        contactValue.put("raw_contact_id",count_id);
        contactValue.put("mimetype","vnd.android.cursor.item/phone_v2");
        getContentResolver().insert(uri1,contactValue);
        contactValue.clear();

        contactValue.put("data1","478569@qq.com");
        contactValue.put("raw_contact_id",count_id);
        contactValue.put("mimetype","vnd.android.cursor.item/email_v2");
        getContentResolver().insert(uri1,contactValue);
        contactValue.clear();
    }

基本思路,先从raw_contact表中获取当前联系人的个数,然后在加上1之后插入联系人,



getContentResolver()内容解析者查询联系人、插入联系人的更多相关文章

  1. android102 查询,插入联系人

    package com.itheima.getcontacts; import com.itheima.getcontacts.domain.Contact; import android.net.U ...

  2. Android 之内容提供者 内容解析者 内容观察者

    contentProvider:ContentProvider在Android中的作用是对外提供数据,除了可以为所在应用提供数据外,还可以共享数据给其他应用,这是Android中解决应用之间数据共享的 ...

  3. JDBC连接(MySql)数据库步骤,以及查询、插入、删除、更新等十一个处理数据库信息的功能

    主要内容:  JDBC连接数据库步骤. 一个简单详细的查询数据的例子. 封装连接数据库,释放数据库连接方法. 实现查询,插入,删除,更新等十一个处理数据库信息的功能.(包括事务处理,批量更新等) 把十 ...

  4. IdentityServer4源码解析_5_查询用户信息接口

    协议简析 UserInfo接口是OAuth2.0中规定的需要认证访问的接口,可以返回认证用户的声明信息.请求UserInfo接口需要使用通行令牌.响应报文通常是json数据格式,包含了一组claim键 ...

  5. gradle相关配置内容解析

    gradle 项目的构建工具,基于groovy语言.主要用于管理依赖包. as中一般将gradle下载在C:\Documents and Settings<用户名>.gradle\wrap ...

  6. 使用PDO连接数据库 查询和插入乱码的解决方法

    问题:PDO连接数据库后,查询和插入中文到数据库,出现乱码,如图: 解决方法: 法1: try{ $opts_values = array(PDO::MYSQL_ATTR_INIT_COMMAND=& ...

  7. 把一个select查询结果插入到一个表(可选指定字段和值实例)

    把一个select查询结果插入到一个表(可选指定字段和值实例) insert into  bak (cc,yf) select cc,9 from ket insert into bak (cc,yf ...

  8. 写了一个Windows API Viewer,提供VBA语句的导出功能。提供两万多个API的MSDN链接内容的本地查询

    始出处:http://www.cnblogs.com/Charltsing/p/APIViewer.html QQ:564955427,QQ群:550672198 世面上的API Viewer已经不少 ...

  9. Oracle Blob查询和插入

    注:本文来源于<Oracle Blob查询和插入> 插入 UPDATE cmm05 SET OUTFILE = to_blob('12345690'): 查询: SELECT utl_ra ...

随机推荐

  1. emacs 新手笔记(四) —— 使用 dired 完成一些简单的文件和目录操作

    ilocker:关注 Android 安全(新入行,0基础) QQ: 2597294287 据说熟悉了 dired,就可以在 emacs 下轻松管理文件和目录了,甚至不再需要 shell 和桌面操作. ...

  2. python 笔记(一) —— 不要误用 ++i、--i

    ilocker:关注 Android 安全(新手) QQ: 2597294287 在 python 中也可以写 ++i,但含义完全不同于 c/c++.python 的 ++i 并不是将 i 自增 1, ...

  3. <代码整洁之道>、<java与模式>、<head first设计模式>读书笔记集合

    一.前言                                                                                       几个月前的看书笔记 ...

  4. Spring MVC @ResponseBody返回中文字符串乱码问题

    朋友做小项目练手的时候遇到的,着实让他郁闷够呛..这个问题的确很恶心.. 项目中引用的json包,直接用@ResponseBody注解返回json字符串..有关这个的乱码问题网上很多,各种花样各种转码 ...

  5. Openxml入门---Openxm读取Excel数据

    Openxml读取Excel数据: 有些问题,如果当Cell 里面是 日期和浮点型的话,对应的Cell.DataType==Null,对应的时间会转换为一个浮点型,对于这块可以通过DateTime.F ...

  6. poj 2278 DNASequnce AC自动机

    地址:http://poj.org/problem?id=2778 题目: DNA Sequence Time Limit: 1000MS   Memory Limit: 65536K Total S ...

  7. 2016-2017 ACM-ICPC, NEERC, Southern Subregional Contest (Online Mirror, ACM-ICPC Rules, Teams Preferred)

    A 思路: 贪心,每次要么选两个最大的,要么选三个,因为一个数(除了1)都可以拆成2和3相加,直到所有的数都相同就停止,这时就可以得到答案了; C: 二分+bfs,二分答案,然后bfs找出距离小于等于 ...

  8. Maven学习(三)生命周期

    maven有三套生命周期 1.clean       清理项目 2.default     构建项目 3.site           建立项目站点 每套生命周期都包含了一些阶段,这些阶段是有序的,后 ...

  9. flexslider.js和waypoints.js一起用时的巨坑

    Flexslider has a callback API where you can execute functions after various actions:https://github.c ...

  10. net面试 ASP.NET页面传值的各种方法和分析 (copy)

    Web页面是无状态的, 服务器对每一次请求都认为来自不同用户,因此,变量的状态在连续对同一页面的多次请求之间或在页面跳转时不会被保留.在用ASP.NET 设计开发一个Web系统时, 遇到一个重要的问题 ...