数据是应用的核心(该话不是我说的,某本书上看到的),在Android的 应用程序中我们经常需要调用通信录,比如给联系人发送贺卡,发送Email。 我们已经知道可以通过ContentProvider去拿到数据,但是其uri如何得到呢。 这就需要我们去查看文档,但是Android开发者指南已经很久没有更新过了, 上面的URI有很多也是错误的,我们必须通过自己查看源文件来找到uri, 然后才可以拿到正确的数据。 以下代码是通过测试类来测试该方法,注释里的部分是通过ContactsContract.Contacts 这个类里的常量获取uri以及id。 而方法中确实通过查看SQLite来获取字段的 package com.sina.contacts; import java.util.ArrayList; import android.content.ContentProviderOperation; import android.content.ContentProviderResult; import android.content.ContentResolver; import android.content.ContentUris; import android.content.ContentValues; import android.database.Cursor; import android.net.Uri; import android.provider.ContactsContract; import android.provider.ContactsContract.RawContacts; import android.provider.ContactsContract.CommonDataKinds.Email; import android.provider.ContactsContract.CommonDataKinds.Phone; import android.provider.ContactsContract.CommonDataKinds.StructuredName; import android.provider.ContactsContract.Contacts.Data; import android.test.AndroidTestCase; import android.util.Log; public class ContactsTest extends AndroidTestCase { public static final String TAG = "ContactsTest"; StringBuffer sb=new StringBuffer(); public void testGetAllContacts()throws Exception{ ContentResolver cr =this.getContext().getContentResolver(); Uri uri=ContactsContract.Contacts.CONTENT_URI; Cursor cursor = cr.query(uri,null, null, null, null); while(cursor.moveToNext()){ String contactId =cursor.getString(cursor.getColumnIndex("_id")); String contactName =cursor.getString(cursor.getColumnIndex("display_name")); sb.append(contactId).append(","+contactName+","); Uri phoneUri=Uri.parse("content://com.android.contacts/data/phones"); Cursor phoneCursor = cr.query(phoneUri, null, "raw_contact_id=?", new String[]{contactId}, null); while(phoneCursor.moveToNext()){ String phoneNumber=phoneCursor.getString(phoneCursor.getColumnIndex("data1")); sb.append(phoneNumber+","); } Uri emailUri=Uri.parse("content://com.android.contacts/data/emails"); Cursor emailCursor=cr.query(emailUri, null, "raw_contact_id="+contactId, null, null); while(emailCursor.moveToNext()){ String email = emailCursor.getString(emailCursor.getColumnIndex("data1")); sb.append(email+". "); } } Log.i(TAG, sb.toString()); } public void testInsert() { ContentValues values = new ContentValues(); Uri rawContactUri = this.getContext().getContentResolver().insert( RawContacts.CONTENT_URI, values); long rawContactId = ContentUris.parseId(rawContactUri); // 往data表入姓名数据 values.clear(); values.put(Data.RAW_CONTACT_ID, rawContactId); values.put(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE);// 内容类型 values.put(StructuredName.GIVEN_NAME, "李天山"); this.getContext().getContentResolver().insert( android.provider.ContactsContract.Data.CONTENT_URI, values); // 往data表入电话数据 values.clear(); values.put(Data.RAW_CONTACT_ID, rawContactId); values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE); values.put(Phone.NUMBER, "13921009789"); values.put(Phone.TYPE, Phone.TYPE_MOBILE); this.getContext().getContentResolver().insert( android.provider.ContactsContract.Data.CONTENT_URI, values); // 往data表入Email数据 values.clear(); values.put(Data.RAW_CONTACT_ID, rawContactId); values.put(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE); values.put(Email.DATA, "liming@itcast.cn"); values.put(Email.TYPE, Email.TYPE_WORK); this.getContext().getContentResolver().insert( android.provider.ContactsContract.Data.CONTENT_URI, values); } // 批量添加,处于同一个事务中 public void testSave() throws Throwable { // 文档位置:reference/android/provider/ContactsContract.RawContacts.html ArrayList<ContentProviderOperation> ops = new ArrayList<ContentProviderOperation>(); int rawContactInsertIndex = ops.size(); ops.add(ContentProviderOperation.newInsert(RawContacts.CONTENT_URI) .withValue(RawContacts.ACCOUNT_TYPE, null).withValue( RawContacts.ACCOUNT_NAME, null).build()); // 文档位置:reference/android/provider/ContactsContract.Data.html ops.add(ContentProviderOperation.newInsert( android.provider.ContactsContract.Data.CONTENT_URI) .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex).withValue(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE).withValue( StructuredName.GIVEN_NAME, "赵薇").build()); ops.add(ContentProviderOperation.newInsert( android.provider.ContactsContract.Data.CONTENT_URI) .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex).withValue(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE).withValue(Phone.NUMBER, "13671323809").withValue(Phone.TYPE, Phone.TYPE_MOBILE) .withValue(Phone.LABEL, "手机号").build()); ops.add(ContentProviderOperation.newInsert( android.provider.ContactsContract.Data.CONTENT_URI) .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex).withValue(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE).withValue(Email.DATA, "liming@itcast.cn").withValue(Email.TYPE, Email.TYPE_WORK).build()); ContentProviderResult[] results = this.getContext() .getContentResolver().applyBatch(ContactsContract.AUTHORITY, ops); for (ContentProviderResult result : results) { Log.i(TAG, result.uri.toString()); } } }