getContentResolver()内容解析者查询联系人、插入联系人
首先,我们需要知道的两个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()内容解析者查询联系人、插入联系人的更多相关文章
- android102 查询,插入联系人
package com.itheima.getcontacts; import com.itheima.getcontacts.domain.Contact; import android.net.U ...
- Android 之内容提供者 内容解析者 内容观察者
contentProvider:ContentProvider在Android中的作用是对外提供数据,除了可以为所在应用提供数据外,还可以共享数据给其他应用,这是Android中解决应用之间数据共享的 ...
- JDBC连接(MySql)数据库步骤,以及查询、插入、删除、更新等十一个处理数据库信息的功能
主要内容: JDBC连接数据库步骤. 一个简单详细的查询数据的例子. 封装连接数据库,释放数据库连接方法. 实现查询,插入,删除,更新等十一个处理数据库信息的功能.(包括事务处理,批量更新等) 把十 ...
- IdentityServer4源码解析_5_查询用户信息接口
协议简析 UserInfo接口是OAuth2.0中规定的需要认证访问的接口,可以返回认证用户的声明信息.请求UserInfo接口需要使用通行令牌.响应报文通常是json数据格式,包含了一组claim键 ...
- gradle相关配置内容解析
gradle 项目的构建工具,基于groovy语言.主要用于管理依赖包. as中一般将gradle下载在C:\Documents and Settings<用户名>.gradle\wrap ...
- 使用PDO连接数据库 查询和插入乱码的解决方法
问题:PDO连接数据库后,查询和插入中文到数据库,出现乱码,如图: 解决方法: 法1: try{ $opts_values = array(PDO::MYSQL_ATTR_INIT_COMMAND=& ...
- 把一个select查询结果插入到一个表(可选指定字段和值实例)
把一个select查询结果插入到一个表(可选指定字段和值实例) insert into bak (cc,yf) select cc,9 from ket insert into bak (cc,yf ...
- 写了一个Windows API Viewer,提供VBA语句的导出功能。提供两万多个API的MSDN链接内容的本地查询
始出处:http://www.cnblogs.com/Charltsing/p/APIViewer.html QQ:564955427,QQ群:550672198 世面上的API Viewer已经不少 ...
- Oracle Blob查询和插入
注:本文来源于<Oracle Blob查询和插入> 插入 UPDATE cmm05 SET OUTFILE = to_blob('12345690'): 查询: SELECT utl_ra ...
随机推荐
- Ubuntu下安装Pyenv不成功,求指教
虚拟机:VMware12.0 操作系统:Ubuntu16.04 LTS (新安装系统) 已经按照网上的步骤: 1.安装git: $sudo apt-get install git 2.安装依赖包: $ ...
- hw 要的是螺丝钉
日前突然接到华为HR的电话,叫我去面试。本来我的工作和工资收入等各方面在本地也还算可以,没有想要跳槽。但是本着去看看有没有更好机会的想法就去了。 9:30到了现场后,在那里等了很久,一个考官上来问了 ...
- Ubuntu14.02.2下安装JDK并配置Jetty服务器
首先第一步先取得JDK的安装文件,由于我的系统是64位的,所以安装包是jdk-7u80-linux-x64.gz 上传到unbuntu服务器下 执行tar -xvf jdk-7u80-linux-x6 ...
- shell编程入门
背景知识 Shell 是用户与内核进行交互操作的一种接口,是 Linux 最重要的软件之一.目前最流行的 Shell 称为 bash Shell,bash Shell 脚本编程以其简洁.高效而著称,多 ...
- Android ViewPager再探:增加滑动指示条
上一篇:<Android ViewPager初探:让页面滑动起来> ViewPager只是左右滑动有些丑,也不知道当前位于第几页面. 可以在上方加入滑动指示条,来确定当前位置. 只需要修改 ...
- 报表性能优化方案之单数据集分页SQL实现层式报表
1.概述 我们知道,行式引擎按页取数只适用于Oracle,mysql,hsql和sqlserver2008及以上数据库,其他数据库,如access,sqlserver2005,sqlite等必须编写分 ...
- js生成[n,m]的随机数
一.预备知识 Math.ceil(); //向上取整. Math.floor(); //向下取整. Math.round(); //四舍五入. Math.random(); //0.0 ~ 1 ...
- 洛谷10月月赛Round.1| P3400 仓鼠窝[单调栈]
题目描述 萌萌哒的Created equal是一只小仓鼠,小仓鼠自然有仓鼠窝啦. 仓鼠窝是一个由n*m个格子组成的行数为n.列数为m的矩阵.小仓鼠现在想要知道,这个矩阵中有多少个子矩阵!(实际上就是有 ...
- POJ2230Watchcow[欧拉回路]
Watchcow Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 7512 Accepted: 3290 Specia ...
- AC日记——回文子串 openjudge 1.7 34
34:回文子串 总时间限制: 1000ms 内存限制: 65536kB 描述 给定一个字符串,输出所有长度至少为2的回文子串. 回文子串即从左往右输出和从右往左输出结果是一样的字符串,比如:abb ...