ContentProvider往通讯录添加联系人和获取联系人
2015-03-20 20:18
471 查看
在Android中,可以使用ContentResolver对通信录中的数据进行添加、删除、修改和查询操作。
在对联系人进行操作时需加入以下两个权限
<!-- 添加操作联系人的权限 -->
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
<!-- 联系人相关的uri -->
content://com.android.contacts/contacts 操作的数据是联系人信息Uri
content://com.android.contacts/data/phones 联系人电话Uri
content://com.android.contacts/data/emails 联系人Email Uri
一、清单文件
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.ljq.contact" android:versionCode="1"
android:versionName="1.0">
<application android:icon="@drawable/icon"
android:label="@string/app_name">
<uses-library android:name="android.test.runner" />
<activity android:name=".ContactActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category
android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
<uses-sdk android:minSdkVersion="7" />
<instrumentation
android:name="android.test.InstrumentationTestRunner"
android:targetPackage="com.ljq.contact"
android:label="Tests for My App" />
<!-- 添加联系人权限 -->
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
</manifest>
获取联系人和添加联系人
package com.ljq.contact;
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.Data;
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.test.AndroidTestCase;
import android.util.Log;
public class ContactTest extends AndroidTestCase{
private static final String TAG = "ContactTest";
/**
* 获取通讯录中联系人
*/
public void testGetContact(){
ContentResolver contentResolver = this.getContext().getContentResolver();
Uri uri = Uri.parse("content://com.android.contacts/contacts");
Cursor cursor = contentResolver.query(uri, null, null, null, null);
while(cursor.moveToNext()){
// 获取联系人姓名
StringBuilder sb = new StringBuilder();
String contactId = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));
String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
sb.append("contactId=").append(contactId).append(",name=").append(name);
//获取联系人手机号码
Cursor phones = contentResolver.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
null,
ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = "+ contactId,
null, null);
while(phones.moveToNext()){
String phone = phones.getString(phones.getColumnIndex("data1"));
sb.append(",phone=").append(phone);
}
//获取联系人email
Cursor emails = contentResolver.query(ContactsContract.CommonDataKinds.Email.CONTENT_URI,
null,
ContactsContract.CommonDataKinds.Email.CONTACT_ID + " = " + contactId,
null, null);
while(emails.moveToNext()){
String email = emails.getString(emails.getColumnIndex("data1"));
sb.append(",email=").append(email);
}
Log.i(TAG, sb.toString());
}
}
/**
* 首先向RawContacts.CONTENT_URI执行一个空值插入,目的是获取系统返回的rawContactId
*
* 这是后面插入data表的数据,只有执行空值插入,才能使插入的联系人在通讯录里可见
*/
public void testInsert(){
ContentValues values = new ContentValues();
//首先向RawContacts.CONTENT_URI执行一个空值插入,目的是获取系统返回的rawContactId
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, "zhangsan");
this.getContext().getContentResolver().insert(
android.provider.ContactsContract.Data.CONTENT_URI, values);
//往data表入电话数据
values.clear();
values.put(android.provider.ContactsContract.Contacts.Data.RAW_CONTACT_ID, rawContactId);
values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
values.put(Phone.NUMBER, "5554");
values.put(Phone.TYPE, Phone.TYPE_MOBILE);
this.getContext().getContentResolver().insert(
android.provider.ContactsContract.Data.CONTENT_URI, values);
//往data表入Email数据
values.clear();
values.put(android.provider.ContactsContract.Contacts.Data.RAW_CONTACT_ID, rawContactId);
values.put(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE);
values.put(Email.DATA, "ljq218@126.com");
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 = 0;
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, "lisi")
.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, "5556")
.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, "lisi@126.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());
}
}
public static void addContact(Context context, final String number)
{
// reference\android\provider\ContactsContract.RawContacts.html
ArrayList<ContentProviderOperation> ops = new ArrayList<ContentProviderOperation>();
int rawContactInsertIndex = 0;
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, "lisi")
// .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, number)
.withValue(Phone.TYPE, Phone.TYPE_MOBILE)
.withValue(Phone.PHONE_BLACKLIST, Phone.HAS_BLACKLIST)
.build());
try
{
ContentProviderResult[] results = context.getContentResolver()
.applyBatch(ContactsContract.AUTHORITY, ops);
Log.i(TAG, "addContact--->results[0]:" + results[0]);
long rawContactid = ContentUris.parseId(results[0].uri);
Log.i(TAG, "addContact--->rawContactid:" + rawContactid);
}
catch (RemoteException | OperationApplicationException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
} public static long getRawContactIdByContactId(Context context, final String contactId)
{
ContentResolver contentResolver = context.getContentResolver();
long rawContactId = 0;
Cursor cursor = contentResolver.query(
android.provider.ContactsContract.Contacts.CONTENT_URI, null,
android.provider.ContactsContract.Contacts._ID + " = ?",
new String[] {
contactId
}, null);
if ((cursor != null) && (cursor.moveToNext()))
{
rawContactId = cursor
.getLong(cursor
.getColumnIndex(android.provider.ContactsContract.Contacts.NAME_RAW_CONTACT_ID));
cursor.close();
}
Log.i(TAG, "getRawContactIdByContactId--->rawContactId:" + rawContactId);
return rawContactId;
}
long rawContactId = getRawContactIdByContactId(context, contactId);
ContentValues values1 = new ContentValues();
values1.put(Phone.PHONE_BLACKLIST, 1);
//contentResolver.update(android.provider.ContactsContract.Data.CONTENT_URI, values1,
// Data.RAW_CONTACT_ID + " = ? AND " + Data.MIMETYPE + " = ?", new String[] {
// rawContactId + "", Phone.CONTENT_ITEM_TYPE
contentResolver.update(android.provider.ContactsContract.Data.CONTENT_URI, values1,
Data.RAW_CONTACT_ID + " = ?", new String[] {
rawContactId + ""
});
private void setTablesAndProjectionMapForContactsIsBlacklist(SQLiteQueryBuilder qb,
String[] projection,
boolean includeDataUsageStat, boolean isblacklist)
{
final String OUTER_DATA_RAW_CONTACTS_ID = Data.RAW_CONTACT_ID;
StringBuilder sb = new StringBuilder();
sb.append(Views.CONTACTS);
if (isblacklist)
{
// if (ContactsDatabaseHelper.isInProjection(
// projection, Tables.PHONE_BLACKLIST, Tables.PHONE_BLACKLIST))
{
sb.append(" INNER JOIN ");
String toAppend =
" ((SELECT DISTINCT "
+ Data.RAW_CONTACT_ID + " AS " + OUTER_DATA_RAW_CONTACTS_ID
// + "," + Tables.DATA + "." + Tables.PHONE_BLACKLIST + " AS " +
// Tables.PHONE_BLACKLIST
+ " FROM " + Tables.DATA + " WHERE "
+ "("
+ Tables.DATA + "." + Phone.PHONE_BLACKLIST + "=" + 1
+ " AND "
+ DataColumns.CONCRETE_MIMETYPE_ID + "="
+ "(SELECT " + MimetypesColumns._ID
+ " FROM " + Tables.MIMETYPES
+ " WHERE "
+ MimetypesColumns.CONCRETE_MIMETYPE + "="
+ "'" + Phone.CONTENT_ITEM_TYPE + "'"
+ ")"
+ ")"
+ ")" + " AS blacklist_number_table" + ")"
+ " ON ("
+ OUTER_DATA_RAW_CONTACTS_ID + "=" + Views.CONTACTS + "."
+ Contacts.NAME_RAW_CONTACT_ID + ")";
sb.append(toAppend);
}
}
else
{
// if (ContactsDatabaseHelper.isInProjection(
// projection, Tables.PHONE_BLACKLIST, Tables.PHONE_BLACKLIST))
{
sb.append(" INNER JOIN ");
String toAppend =
" ((SELECT DISTINCT "
+ Data.RAW_CONTACT_ID + " AS " + OUTER_DATA_RAW_CONTACTS_ID
// + "," + Tables.DATA + "." + Tables.PHONE_BLACKLIST + " AS " +
// Tables.PHONE_BLACKLIST
+ " FROM " + Tables.DATA + " WHERE "
+ "("
+ Tables.DATA + "." + Phone.PHONE_BLACKLIST + "=" + 0
+ " AND "
+ DataColumns.CONCRETE_MIMETYPE_ID + "="
+ "(SELECT " + MimetypesColumns._ID
+ " FROM " + Tables.MIMETYPES
+ " WHERE "
+ MimetypesColumns.CONCRETE_MIMETYPE + "="
+ "'" + Phone.CONTENT_ITEM_TYPE + "'"
+ ")"
+ ")"
+ ")" + " AS blacklist_number_table" + ")"
+ " ON ("
+ OUTER_DATA_RAW_CONTACTS_ID + "=" + Views.CONTACTS + "."
+ Contacts.NAME_RAW_CONTACT_ID + ")";
sb.append(toAppend);
}
}
// luyonggang 2015-03-25 modified begin for debug
Log.i(TAG,
"setTablesAndProjectionMapForContactsIsBlacklist--->projection:"
+ Arrays.toString(projection));
Log.i(TAG, "setTablesAndProjectionMapForContactsIsBlacklist--->sb1:" + sb);
// luyonggang 2015-03-25 modified end for debug
appendContactPresenceJoin(sb, projection, Contacts._ID);
appendContactStatusUpdateJoin(sb, projection, ContactsColumns.LAST_STATUS_UPDATE_ID);
// luyonggang 2015-03-25 modified begin for debug
Log.i(TAG, "setTablesAndProjectionMapForContactsIsBlacklist--->sb2:" + sb);
// luyonggang 2015-03-25 modified end for debug
qb.setTables(sb.toString());
qb.setProjectionMap(sContactsProjectionMap);
}
}
在对联系人进行操作时需加入以下两个权限
<!-- 添加操作联系人的权限 -->
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
<!-- 联系人相关的uri -->
content://com.android.contacts/contacts 操作的数据是联系人信息Uri
content://com.android.contacts/data/phones 联系人电话Uri
content://com.android.contacts/data/emails 联系人Email Uri
一、清单文件
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.ljq.contact" android:versionCode="1"
android:versionName="1.0">
<application android:icon="@drawable/icon"
android:label="@string/app_name">
<uses-library android:name="android.test.runner" />
<activity android:name=".ContactActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category
android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
<uses-sdk android:minSdkVersion="7" />
<instrumentation
android:name="android.test.InstrumentationTestRunner"
android:targetPackage="com.ljq.contact"
android:label="Tests for My App" />
<!-- 添加联系人权限 -->
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
</manifest>
获取联系人和添加联系人
package com.ljq.contact;
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.Data;
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.test.AndroidTestCase;
import android.util.Log;
public class ContactTest extends AndroidTestCase{
private static final String TAG = "ContactTest";
/**
* 获取通讯录中联系人
*/
public void testGetContact(){
ContentResolver contentResolver = this.getContext().getContentResolver();
Uri uri = Uri.parse("content://com.android.contacts/contacts");
Cursor cursor = contentResolver.query(uri, null, null, null, null);
while(cursor.moveToNext()){
// 获取联系人姓名
StringBuilder sb = new StringBuilder();
String contactId = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));
String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
sb.append("contactId=").append(contactId).append(",name=").append(name);
//获取联系人手机号码
Cursor phones = contentResolver.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
null,
ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = "+ contactId,
null, null);
while(phones.moveToNext()){
String phone = phones.getString(phones.getColumnIndex("data1"));
sb.append(",phone=").append(phone);
}
//获取联系人email
Cursor emails = contentResolver.query(ContactsContract.CommonDataKinds.Email.CONTENT_URI,
null,
ContactsContract.CommonDataKinds.Email.CONTACT_ID + " = " + contactId,
null, null);
while(emails.moveToNext()){
String email = emails.getString(emails.getColumnIndex("data1"));
sb.append(",email=").append(email);
}
Log.i(TAG, sb.toString());
}
}
/**
* 首先向RawContacts.CONTENT_URI执行一个空值插入,目的是获取系统返回的rawContactId
*
* 这是后面插入data表的数据,只有执行空值插入,才能使插入的联系人在通讯录里可见
*/
public void testInsert(){
ContentValues values = new ContentValues();
//首先向RawContacts.CONTENT_URI执行一个空值插入,目的是获取系统返回的rawContactId
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, "zhangsan");
this.getContext().getContentResolver().insert(
android.provider.ContactsContract.Data.CONTENT_URI, values);
//往data表入电话数据
values.clear();
values.put(android.provider.ContactsContract.Contacts.Data.RAW_CONTACT_ID, rawContactId);
values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
values.put(Phone.NUMBER, "5554");
values.put(Phone.TYPE, Phone.TYPE_MOBILE);
this.getContext().getContentResolver().insert(
android.provider.ContactsContract.Data.CONTENT_URI, values);
//往data表入Email数据
values.clear();
values.put(android.provider.ContactsContract.Contacts.Data.RAW_CONTACT_ID, rawContactId);
values.put(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE);
values.put(Email.DATA, "ljq218@126.com");
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 = 0;
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, "lisi")
.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, "5556")
.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, "lisi@126.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());
}
}
public static void addContact(Context context, final String number)
{
// reference\android\provider\ContactsContract.RawContacts.html
ArrayList<ContentProviderOperation> ops = new ArrayList<ContentProviderOperation>();
int rawContactInsertIndex = 0;
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, "lisi")
// .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, number)
.withValue(Phone.TYPE, Phone.TYPE_MOBILE)
.withValue(Phone.PHONE_BLACKLIST, Phone.HAS_BLACKLIST)
.build());
try
{
ContentProviderResult[] results = context.getContentResolver()
.applyBatch(ContactsContract.AUTHORITY, ops);
Log.i(TAG, "addContact--->results[0]:" + results[0]);
long rawContactid = ContentUris.parseId(results[0].uri);
Log.i(TAG, "addContact--->rawContactid:" + rawContactid);
}
catch (RemoteException | OperationApplicationException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
} public static long getRawContactIdByContactId(Context context, final String contactId)
{
ContentResolver contentResolver = context.getContentResolver();
long rawContactId = 0;
Cursor cursor = contentResolver.query(
android.provider.ContactsContract.Contacts.CONTENT_URI, null,
android.provider.ContactsContract.Contacts._ID + " = ?",
new String[] {
contactId
}, null);
if ((cursor != null) && (cursor.moveToNext()))
{
rawContactId = cursor
.getLong(cursor
.getColumnIndex(android.provider.ContactsContract.Contacts.NAME_RAW_CONTACT_ID));
cursor.close();
}
Log.i(TAG, "getRawContactIdByContactId--->rawContactId:" + rawContactId);
return rawContactId;
}
long rawContactId = getRawContactIdByContactId(context, contactId);
ContentValues values1 = new ContentValues();
values1.put(Phone.PHONE_BLACKLIST, 1);
//contentResolver.update(android.provider.ContactsContract.Data.CONTENT_URI, values1,
// Data.RAW_CONTACT_ID + " = ? AND " + Data.MIMETYPE + " = ?", new String[] {
// rawContactId + "", Phone.CONTENT_ITEM_TYPE
contentResolver.update(android.provider.ContactsContract.Data.CONTENT_URI, values1,
Data.RAW_CONTACT_ID + " = ?", new String[] {
rawContactId + ""
});
private void setTablesAndProjectionMapForContactsIsBlacklist(SQLiteQueryBuilder qb,
String[] projection,
boolean includeDataUsageStat, boolean isblacklist)
{
final String OUTER_DATA_RAW_CONTACTS_ID = Data.RAW_CONTACT_ID;
StringBuilder sb = new StringBuilder();
sb.append(Views.CONTACTS);
if (isblacklist)
{
// if (ContactsDatabaseHelper.isInProjection(
// projection, Tables.PHONE_BLACKLIST, Tables.PHONE_BLACKLIST))
{
sb.append(" INNER JOIN ");
String toAppend =
" ((SELECT DISTINCT "
+ Data.RAW_CONTACT_ID + " AS " + OUTER_DATA_RAW_CONTACTS_ID
// + "," + Tables.DATA + "." + Tables.PHONE_BLACKLIST + " AS " +
// Tables.PHONE_BLACKLIST
+ " FROM " + Tables.DATA + " WHERE "
+ "("
+ Tables.DATA + "." + Phone.PHONE_BLACKLIST + "=" + 1
+ " AND "
+ DataColumns.CONCRETE_MIMETYPE_ID + "="
+ "(SELECT " + MimetypesColumns._ID
+ " FROM " + Tables.MIMETYPES
+ " WHERE "
+ MimetypesColumns.CONCRETE_MIMETYPE + "="
+ "'" + Phone.CONTENT_ITEM_TYPE + "'"
+ ")"
+ ")"
+ ")" + " AS blacklist_number_table" + ")"
+ " ON ("
+ OUTER_DATA_RAW_CONTACTS_ID + "=" + Views.CONTACTS + "."
+ Contacts.NAME_RAW_CONTACT_ID + ")";
sb.append(toAppend);
}
}
else
{
// if (ContactsDatabaseHelper.isInProjection(
// projection, Tables.PHONE_BLACKLIST, Tables.PHONE_BLACKLIST))
{
sb.append(" INNER JOIN ");
String toAppend =
" ((SELECT DISTINCT "
+ Data.RAW_CONTACT_ID + " AS " + OUTER_DATA_RAW_CONTACTS_ID
// + "," + Tables.DATA + "." + Tables.PHONE_BLACKLIST + " AS " +
// Tables.PHONE_BLACKLIST
+ " FROM " + Tables.DATA + " WHERE "
+ "("
+ Tables.DATA + "." + Phone.PHONE_BLACKLIST + "=" + 0
+ " AND "
+ DataColumns.CONCRETE_MIMETYPE_ID + "="
+ "(SELECT " + MimetypesColumns._ID
+ " FROM " + Tables.MIMETYPES
+ " WHERE "
+ MimetypesColumns.CONCRETE_MIMETYPE + "="
+ "'" + Phone.CONTENT_ITEM_TYPE + "'"
+ ")"
+ ")"
+ ")" + " AS blacklist_number_table" + ")"
+ " ON ("
+ OUTER_DATA_RAW_CONTACTS_ID + "=" + Views.CONTACTS + "."
+ Contacts.NAME_RAW_CONTACT_ID + ")";
sb.append(toAppend);
}
}
// luyonggang 2015-03-25 modified begin for debug
Log.i(TAG,
"setTablesAndProjectionMapForContactsIsBlacklist--->projection:"
+ Arrays.toString(projection));
Log.i(TAG, "setTablesAndProjectionMapForContactsIsBlacklist--->sb1:" + sb);
// luyonggang 2015-03-25 modified end for debug
appendContactPresenceJoin(sb, projection, Contacts._ID);
appendContactStatusUpdateJoin(sb, projection, ContactsColumns.LAST_STATUS_UPDATE_ID);
// luyonggang 2015-03-25 modified begin for debug
Log.i(TAG, "setTablesAndProjectionMapForContactsIsBlacklist--->sb2:" + sb);
// luyonggang 2015-03-25 modified end for debug
qb.setTables(sb.toString());
qb.setProjectionMap(sContactsProjectionMap);
}
}
相关文章推荐
- ContentProvider往通讯录添加联系人和获取联系人
- 十四、ContentProvider往通讯录添加联系人和获取联系人
- ContentProvider往通讯录添加联系人和获取联系人
- 十四、ContentProvider往通讯录添加联系人和获取联系人
- (4.1.26.2)ContentProvider往通讯录添加联系人和获取联系人
- ContentProvider往通讯录添加联系人和获取联系人
- android 联系人操作: ContentProvider往通讯录添加联系人和获取联系人
- 十四、ContentProvider往通讯录添加联系人和获取联系人
- ContentProvider往通讯录添加联系人和获取联系人
- ContentProvider往通讯录添加联系人和获取联系人
- 十四、ContentProvider往通讯录添加联系人和获取联系人
- 十四、ContentProvider往通讯录添加联系人和获取联系人
- Project——使用内容提供者从通讯录中获取联系人或添加联系人
- Android ContentProvider往通讯录添加联系人
- 演示ContentProvider使用--获取通讯录所有联系人号码、email的例子
- ContentProvider与隐式Intent获取手机联系人通讯录信息或电话的方法
- 使用ContentProvider添加获取通讯录信息
- ContentProvider获取系统的电话号码绑定到ListView以及跳转通讯录获区联系人信息绑定到前台。
- ContentProvider与隐式Intent获取手机联系人通讯录信息或电话的方法
- Android ContentProvider(类容提供者)之操作通讯录联系人 添加查询联系人