系统的联系人在data/data文件夹的com.android.providers.contacts包的contacts2.db文件中,了解系统的联系人需要3个数据库
raw_contacts表:每一个联系人都有一条数据,contact_id:联系人id和display_name:联系人的名字,例如下面有3个联系人,姓名分别在下面圈中所示
data表:存放联系人的详细信息,每一行存放一个联系人的单独信息,比如电话号码和邮箱分别占据一行。raw_contact_id来区别哪一个数据是哪一个联系人的,minetype_id来确定哪一个数据代表着什么内容(号码,邮箱等等),data1是联系人的具体信息
minetype表:不同的id代表不同的类型
查询联系人的信息,分为2步,第一步是raw_contacts中查询到联系人的ID,第二步是data表中读取具体的联系人的数据
插入的时候,首先在raw_contacts表中插入联系人的ID,再在data表中插入内容。插入数据之前先做一个查询操作,以确定添加的ID该是多少,原来表的ID加1
代码实现查询系统联系人
权限
activity_main.xml
MainAcitvity.java
package com.ldw.contacts;
import android.app.Activity;
import android.content.ContentResolver;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
import com.ldw.contacts.bean.Contact;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void click(View v){
//通过内容提供者访问联系人数据库
ContentResolver cr = getContentResolver();
//首先从raw_contacts找到联系人的id
Cursor cursorContactId = cr.query(Uri.parse("content://com.android.contacts/raw_contacts"), new String[]{"contact_id"}, null, null, null);
while(cursorContactId.moveToNext()){
String contact_id = cursorContactId.getString(0);
//再到data表里面获取内容,注意只能查询到mimetype而不是mimetype_id因此这里参数是mimetype
Cursor cursorData = cr.query(Uri.parse("content://com.android.contacts/data"), new String[]{"data1", "mimetype"}, "raw_contact_id = ?", new String[]{contact_id}, null);
Contact contact = new Contact();
while(cursorData.moveToNext()){
String data1= cursorData.getString(0);
String mimetype = cursorData.getString(1);
System.out.println(data1 + ";" + mimetype);
//在mimetype表中查询相关type,并把数据存入相对于的属性
if("vnd.android.cursor.item/email_v2".equals(mimetype)){
contact.setEmail(data1);
}
else if("vnd.android.cursor.item/phone_v2".equals(mimetype)){
contact.setPhone(data1);
}
else if("vnd.android.cursor.item/name".equals(mimetype)){
contact.setName(data1);
}
}
System.out.println(contact.toString());
}
}
}
代码实现插入联系人
权限
activity_main.xml
MainActivity.java
package com.ldw.insertContact;
import android.app.Activity;
import android.content.ContentResolver;
import android.content.ContentValues;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
//分为2步,
public void click(View v){
//通过内容提供者访问联系人数据库
ContentResolver cr = getContentResolver();
ContentValues values = new ContentValues();
//先查询raw_contacts表,获取联系人的主键,然后主键加一,就是要插入的联系人的ID
Cursor cursorContactId = cr.query(Uri.parse("content://com.android.contacts/raw_contacts"), new String[]{"contact_id"}, null, null, null);
//初始化联系人的id是1
int contact_id = 1;
if(cursorContactId.moveToNext()){
//获取到主键,再加1
int _id = cursorContactId.getInt(0);
contact_id = _id++;
}
values.put("contact_id", contact_id);
//把id插入到数据库中
cr.insert(Uri.parse("content://com.android.contacts/raw_contacts"), values);
//清除,防止不同表中数据干扰,插入名字
values.clear();
values.put("data1", "EEE");
values.put("nimetype", "vnd.android.cursor.item/name");
values.put("raw_contact_id", contact_id);
cr.insert(Uri.parse("content://com.android.contacts/data"), values);
//清除,防止不同表中数据干扰,插入号码
values.clear();
values.put("data1", "1671812");
values.put("nimetype", "vnd.android.cursor.item/phone_v2");
values.put("raw_contact_id", contact_id);
cr.insert(Uri.parse("content://com.android.contacts/data"), values);
}
}