主要还是用内容提供者ContentProvider来访问数据库
#1.首先布局文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="queryContact"
android:text="查看联系人" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="addContact"
android:text="添加联系人" />
</LinearLayout>
在布局文件中添加了两个事件监听。
#2.在程序中实现
package com.wzw.contacts;
import android.net.Uri;
import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.widget.Toast;
public class MainActivity extends Activity {
private String tag="MainActivity";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void queryContact(View v){
Uri uri=Uri.parse("content://com.android.contacts/raw_contacts");
Uri datauri=Uri.parse("content://com.android.contacts/data");
Cursor cursor = getContentResolver().query(uri, new String[]{"_id"}, null, null, null);
if(cursor!=null && cursor.getCount()>0){
while(cursor.moveToNext()){
//获取raw_contact_id的值,然后再data表中读取数据
int id=cursor.getInt(0);
String selection="raw_contact_id=?";
String selectionArgs[]={String.valueOf(id)};
Cursor c=getContentResolver().query(datauri, new String[]{"data1","mimetype"}, selection, selectionArgs, null);
if(c!=null && c.getCount()>0){
while(c.moveToNext()){
//循环在data中读取数据
String mimetype=c.getString(1);
String data=c.getString(0);
if("vnd.android.cursor.item/email_v2".equals(mimetype)){
Log.i(tag, "Email:"+data);
}else if ("vnd.android.cursor.item/phone_v2".equals(mimetype)) {
Log.i(tag, "联系电话:"+data);
}else if ("vnd.android.cursor.item/name".equals(mimetype)) {
Log.i(tag, "联系姓名:"+data);
}
}
}
}
}
}
public void addContact(View v){
Uri uri=Uri.parse("content://com.android.contacts/raw_contacts");
Uri datauri=Uri.parse("content://com.android.contacts/data");
//1.取出raw_contacts中的最大id
Cursor cursor=getContentResolver().query(uri, new String[]{"contact_id"}, null, null, "contact_id desc limit 1");
if(cursor!=null && cursor.moveToFirst()){
int contact_id=cursor.getInt(0)+1;
cursor.close();
//2.在raw_contacts添加一条ID
ContentValues values=new ContentValues();
values.put("contact_id", contact_id);
getContentResolver().insert(uri, values);
//3.根据上面的contact_id在data中添加三条记录,分别是电话,联系名字,邮箱
//添加邮箱
values=new ContentValues();
values.put("mimetype", "vnd.android.cursor.item/email_v2");
values.put("data1", "bey@163.com");
values.put("raw_contact_id", contact_id);
getContentResolver().insert(datauri, values);
//添加姓名
values=new ContentValues();
values.put("mimetype", "vnd.android.cursor.item/name");
values.put("data1", "中国联通");
values.put("raw_contact_id", contact_id);
getContentResolver().insert(datauri, values);
//添加号码
values=new ContentValues();
values.put("mimetype", "vnd.android.cursor.item/phone_v2");
values.put("data1", "10010");
values.put("raw_contact_id", contact_id);
getContentResolver().insert(datauri, values);
Toast.makeText(this, "添加成功,ID是"+contact_id, 0).show();
}
}
}
#3.另外在清单文件中添加读写联系人权限
<uses-permission android:name="android.permission.READ_CONTACTS"/>
<uses-permission android:name="android.permission.WRITE_CONTACTS"/>