android系统中的联系人也是通过contentprovider来对外提供数据的,我们这里实现获取所有联系人、通过电话号码获取联系人、添加联系人、使用事务添加联系人。
获取所有联系人
1. android系统中的联系人也是通过contentprovider来对外提供数据的
2. 数据库路径为:/data/data/com.android.providers.contacts/database/contacts2.db
3. 我们需要关注的有3张表
raw_contacts:其中保存了联系人id
data:和raw_contacts是多对一的关系,保存了联系人的各项数据
mimetypes:为数据类型
4. provider的authorites为com.android.contacts
5. 查询raw_contacts表的路径为:contacts
6. 查询data表的路径为:contacts/#/data
这个路径为连接查询,要查询“mimetype”字段可以根据“mimetype_id”查询到mimetypes表中的数据
7. 先查询raw_contacts得到每个联系人的id,在使用id从data表中查询对应数据,根据mimetype分类数据
示例:
//查询所有联系人
public void testgetall() {
contentresolver resolver = getcontext().getcontentresolver();
uri uri = uri.parse("content://com.android.contacts/contacts");
cursor idcursor = resolver.query(uri, new string[] { "_id" }, null, null, null);
while (idcursor.movetonext()) {
//获取到raw_contacts表中的id
int id = idcursor.getint(0);
//根据获取到的id查询data表中的数据
uri = uri.parse("content://com.android.contacts/contacts/" + id + "/data");
cursor datacursor = resolver.query(uri, new string[] { "data1", "mimetype" }, null, null, null);
stringbuilder sb = new stringbuilder();
sb.append("id=" + id);
//查询联系人表中的
while (datacursor.movetonext()) {
string data = datacursor.getstring(0);
string type = datacursor.getstring(1);
if ("vnd.android.cursor.item/name".equals(type))
sb.append(", name=" + data);
else if ("vnd.android.cursor.item/phone_v2".equals(type))
sb.append(", phone=" + data);
else if ("vnd.android.cursor.item/email_v2".equals(type))
sb.append(", email=" + data);
}
system.out.println(sb);
}
}
通过电话号码获取联系人
1. 系统内部提供了根据电话号码获取data表数据的功能,路径为:data/phones/filter/*
2. 用电话号码替换“*”部分就可以查到所需数据,获取“display_name”可以获取到联系人显示名
//根据电话号码查询联系人名称
public void testgetname() {
uri uri = uri.parse("content://com.android.contacts/data/phones/filter/1111");
cursor c = resolver.query(uri, new string[] { "display_name" }, null, null, null);
while (c.movetonext()) {
system.out.println(c.getstring(0));
添加联系人
1. 先向raw_contacts表插入id,路径为:raw_contacts
2. 得到id之后再向data表插入数据,路径为:data
//添加联系人
ublic void testinsert() {
contentresolver resolver = getcontext().getcontentresolver();
uri uri = uri.parse("content://com.android.contacts/raw_contacts");
contentvalues values = new contentvalues();
// 向raw_contacts插入一条除了id之外, 其他全部为null的记录, id是自动生成的
long id = contenturis.parseid(resolver.insert(uri, values));
//添加联系人姓名
uri = uri.parse("content://com.android.contacts/data");
values.put("raw_contact_id", id);
values.put("data2", "fhm");
values.put("mimetype", "vnd.android.cursor.item/name");
resolver.insert(uri, values);
//添加联系人电话
values.clear(); // 清空上次的数据
values.put("data1", "18600000000");
values.put("data2", "2");
values.put("mimetype", "vnd.android.cursor.item/phone_v2");
//添加联系人邮箱
values.clear();
values.put("data2", "1");
values.put("mimetype", "vnd.android.cursor.item/email_v2");
使用事务添加联系人
1. 在添加联系人得时候是分多次访问provider,如果在过程中出现异常,会出现数据不完整的情况,这些操作应该放在一次事务中
2. 使用contentresolver的applybatch(string authority,arraylist<contentprovideroperation> operations) 方法可以将多个操作在一个事务中执行
//使用事务添加联系人
public void testinsertbatch() throws exception {
arraylist<contentprovideroperation> operations = new arraylist<contentprovideroperation>();
contentprovideroperation operation1 = contentprovideroperation //
.newinsert(uri.parse("content://com.android.contacts/raw_contacts")) //
.withvalue("_id", null) //
.build();
operations.add(operation1);
contentprovideroperation operation2 = contentprovideroperation //
.newinsert(uri.parse("content://com.android.contacts/data")) //
.withvaluebackreference("raw_contact_id", 0) //
.withvalue("data2", "zzh") //
.withvalue("mimetype", "vnd.android.cursor.item/name") //
operations.add(operation2);
contentprovideroperation operation3 = contentprovideroperation //
.withvalue("data1", "18612312312") //
.withvalue("data2", "2") //
.withvalue("mimetype", "vnd.android.cursor.item/phone_v2") //
operations.add(operation3);
contentprovideroperation operation4 = contentprovideroperation //
.withvalue("mimetype", "vnd.android.cursor.item/email_v2") //
operations.add(operation4);
// 在事务中对多个操作批量执行
resolver.applybatch("com.android.contacts", operations);
转自:http://blog.csdn.net/chaoyu168/article/details/48969257