使用new'ish API进出口插入我的手机/更新联系人和我用这种方法来更新他们..
字符串selectArgs1 = Data.CONTACT_ID +=?AND+ Data.MIMETYPE +=+ Note.CONTENT_ITEM_TYPE +'+和+ Email.TYPE + =?;
的String [] selectArgs2 =新的String [] {的ContactID,将String.valueOf(Email.TYPE_OTHER)};
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(selectArgs1,selectArgs2)
.withValue(Note.Note,hello@hi.com)
。建立());
这是所有工作正常,除非我得到更新注意事项。没有一个 Note.Type_1
之类的东西,所以我不知道放在selectArgs1什么,selectArgs2在替换电子邮件.TYPE
和将String.valueOf(Email.TYPE_OTHER)
任何帮助将是多大的preciated。谢谢! :)
公共静态无效updateContact(上下文C中,int recordId所,字符串键,字符串值){
上下文= C;
如果(数据库== NULL)数据库=新SavedContactsDatabase(上下文);
ArrayList的< ContentProviderOperation> operationList =新的ArrayList< ContentProviderOperation>();
ContentProviderOperation.Builder建设者= ContentProviderOperation.newUpdate(Data.CONTENT_URI);
字符串的ContactID =将String.valueOf(recordId所);
字符串selectArgs1 =;
的String [] selectArgs2 = NULL;
字符串类型=;
串子项=;
如果(key.contains(:)){
的String []分割= key.split(:);
键=分割[0];
类型=分割[1];
如果(split.length == 3)子项=分割[2];
}
如果(key.equals(电子邮件)){
如果(type.equals(家)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Email.TYPE_HOME)};
}否则,如果(type.equals(工作)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Email.TYPE_WORK)};
}否则,如果(type.equals(手机)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Email.TYPE_MOBILE)};
}
selectArgs1 = Data.CONTACT_ID +?=和+ Data.MIMETYPE +='+ Email.CONTENT_ITEM_TYPE +'+和+ Email.TYPE +?=;
builder.withSelection(selectArgs1,selectArgs2);
builder.withValue(Email.DATA1,价值);
}
如果(key.equals(昵称)){
如果(type.equals(违约)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Nickname.TYPE_DEFAULT)};
}否则,如果(type.equals(其他名称)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Nickname.TYPE_OTHER_NAME)};
}否则,如果(type.equals(娘家姓)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Nickname.TYPE_MAINDEN_NAME)};
}否则,如果(type.equals(简称)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Nickname.TYPE_SHORT_NAME)};
}否则,如果(type.equals(声母)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Nickname.TYPE_INITIALS)};
}
selectArgs1 = Data.CONTACT_ID +?=和+ Data.MIMETYPE +='+ Nickname.CONTENT_ITEM_TYPE +'+和+ Nickname.TYPE +?=;
builder.withSelection(selectArgs1,selectArgs2);
builder.withValue(Nickname.NAME,价值);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////
如果(key.equals(注)){
selectArgs1 = Data.CONTACT_ID +=和+ Data.MIMETYPE +=+ Note.CONTENT_ITEM_TYPE +';
selectArgs2 =新的String [] {的ContactID,vnd.android.cursor.item /笔记};
builder.withSelection(selectArgs1,selectArgs2);
builder.withValue(Note.NOTEhello@hi.com);
}
/////////////////////////////////////////////////////////////////////////////////////////////////////
如果(key.equals(本组织)){
字符串数据=;
如果(type.equals(「本公司」)){
数据= Organization.COMPANY;
}否则,如果(type.equals(标题)){
数据= Organization.TITLE;
}否则,如果(type.equals(部)){
数据= Organization.DEPARTMENT;
}否则,如果(type.equals(作业Descripiton)){
数据= Organization.JOB_DESCRIPTION;
}否则如果(type.equals(符号)){
数据= Organization.SYMBOL;
}否则,如果(type.equals(拼音名称)){
数据= Organization.PHONETIC_NAME;
}否则,如果(type.equals(办公地点)){
数据= Organization.OFFICE_LOCATION;
}
selectArgs1 = Data.CONTACT_ID +?=和+ Data.MIMETYPE +='+ Organization.CONTENT_ITEM_TYPE +'+和+ Organization.TYPE +?=;
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Organization.TYPE_WORK)};
builder.withSelection(selectArgs1,selectArgs2);
builder.withValue(数据,值);
}
如果(key.equals(手机)){
如果(type.equals(家)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_HOME)};
}否则,如果(type.equals(手机)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_MOBILE)};
}否则,如果(type.equals(工作)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_WORK)};
}否则,如果(type.equals(传真工作)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_FAX_WORK)};
}否则,如果(type.equals(传真首页)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_FAX_HOME)};
}否则,如果(type.equals(寻呼机)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_PAGER)};
}否则,如果(type.equals(其他)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_OTHER)};
}否则,如果(type.equals(回调)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_CALLBACK)};
}否则,如果(type.equals(汽车)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_CAR)};
}否则,如果(type.equals(「本公司主营)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_COMPANY_MAIN)};
}否则,如果(type.equals(ISDN)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_ISDN)};
}否则,如果(type.equals(主)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_MAIN)};
}否则,如果(type.equals(其他传真)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_OTHER_FAX)};
}否则,如果(type.equals(无线)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_RADIO)};
}否则,如果(type.equals(电传)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_TELEX)};
}否则,如果(type.equals(TTY TDD)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_TTY_TDD)};
}否则,如果(type.equals(工作手机)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_WORK_MOBILE)};
}否则,如果(type.equals(工作寻呼机)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_WORK_PAGER)};
}否则,如果(type.equals(助手)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_ASSISTANT)};
}否则,如果(type.equals(MMS)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Phone.TYPE_MMS)};
}
selectArgs1 = Data.CONTACT_ID +?=和+ Data.MIMETYPE +='+ Phone.CONTENT_ITEM_TYPE +'+和+ Phone.TYPE +?=;
builder.withSelection(selectArgs1,selectArgs2);
builder.withValue(Phone.NUMBER,价值);
}
// TODO关系?
////////////////////////////////////////////////// ////////////////////////////////////
如果(key.equals(名称)){
字符串数据=;
如果(type.equals(显示名称)){
数据= StructuredName.DISPLAY_NAME;
}否则,如果(type.equals(赐名)){
数据= StructuredName.GIVEN_NAME;
}否则,如果(type.equals(姓)){
数据= StructuredName.FAMILY_NAME;
}否则,如果(type.equals(preFIX)){
。数据= StructuredName preFIX;
}否则,如果(type.equals(中间名)){
数据= StructuredName.MIDDLE_NAME;
}否则,如果(type.equals(后缀)){
数据= StructuredName.SUFFIX;
}否则,如果(type.equals(拼音赐名)){
数据= StructuredName.PHONETIC_GIVEN_NAME;
}否则,如果(type.equals(拼音中间名)){
数据= StructuredName.PHONETIC_MIDDLE_NAME;
}否则,如果(type.equals(拼音姓)){
数据= StructuredName.PHONETIC_FAMILY_NAME;
}
selectArgs1 = Data.CONTACT_ID +?=和+ Data.MIMETYPE +='+ StructuredName.CONTENT_ITEM_TYPE +'+和+ StructuredName.MIMETYPE +?=;
selectArgs2 =新的String [] {的ContactID,将String.valueOf(StructuredName.MIMETYPE)};
builder.withSelection(selectArgs1,selectArgs2);
builder.withValue(数据,值);
}
////////////////////////////////////////////////// //////////////////////////////////////
如果(key.equals(地址)){
字符串数据=;
如果(type.equals(家)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(CommonDataKinds.StructuredPostal.TYPE_HOME)};
}否则,如果(type.equals(工作)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(CommonDataKinds.StructuredPostal.TYPE_WORK)};
}否则,如果(type.equals(其他)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(CommonDataKinds.StructuredPostal.TYPE_OTHER)};
}
如果(subkey.equals(街道)){
数据= CommonDataKinds.StructuredPostal.STREET;
}否则,如果(subkey.equals(邮政信箱)){
数据= CommonDataKinds.StructuredPostal.POBOX;
}否则,如果(subkey.equals(邻里)){
数据= CommonDataKinds.StructuredPostal.NEIGHBORHOOD;
}否则,如果(subkey.equals(城市)){
数据= CommonDataKinds.StructuredPostal.CITY;
}否则,如果(subkey.equals(地区)){
数据= CommonDataKinds.StructuredPostal.REGION;
}否则,如果(subkey.equals(邮报code)){
数据= CommonDataKinds.StructuredPostal.POST code;
}否则,如果(subkey.equals(国家)){
数据= CommonDataKinds.StructuredPostal.COUNTRY;
}
selectArgs1 = Data.CONTACT_ID +?=和+ Data.MIMETYPE +='+ CommonDataKinds.StructuredPostal.CONTENT_ITEM_TYPE +'+和+ CommonDataKinds.StructuredPostal.TYPE +?=;
builder.withSelection(selectArgs1,selectArgs2);
builder.withValue(数据,值);
}
如果(key.equals(简称网站)){
如果(type.equals(网页)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Website.TYPE_HOMEPAGE)};
}否则,如果(type.equals(博客)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Website.TYPE_BLOG)};
}否则,如果(type.equals(档案)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Website.TYPE_PROFILE)};
}否则,如果(type.equals(家)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Website.TYPE_HOME)};
}否则,如果(type.equals(工作)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Website.TYPE_WORK)};
}否则,如果(type.equals(FTP)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Website.TYPE_FTP)};
}
selectArgs1 = Data.CONTACT_ID +?=和+ Data.MIMETYPE +='+ Website.CONTENT_ITEM_TYPE +'+和+ Website.TYPE +?=;
builder.withSelection(selectArgs1,selectArgs2);
builder.withValue(Website.URL,价值);
}
如果(key.equals(事件)){
如果(type.equals(周年)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Event.TYPE_ANNIVERSARY)};
}否则,如果(type.equals(生日)){
selectArgs2 =新的String [] {的ContactID,将String.valueOf(Event.TYPE_BIRTHDAY)};
}
selectArgs1 = Data.CONTACT_ID +?=和+ Data.MIMETYPE +='+ Event.CONTENT_ITEM_TYPE +'+和+ Event.type访问+?=;
builder.withSelection(selectArgs1,selectArgs2);
builder.withValue(Event.START_DATE,价值);
}
/ *
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(Data.RAW_CONTACT_ID +=?,新的String [] {} SDF)
.withValue(Email.DATA1,work.hi.com)
.withValue(Email.TYPE,Email.TYPE_WORK)
。建立());
* /
/ *
字符串selectPhone = Data.CONTACT_ID +=?AND+ Data.MIMETYPE +=+
Email.CONTENT_ITEM_TYPE +'+和+ Email.TYPE +?=;
的String [] phoneArgs =新的String [] {的ContactID,将String.valueOf(Email.TYPE_OTHER)};
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(selectPhone,phoneArgs)
.withValue(Email.DATA1,hello@hi.comm)
。建立());
* /
尝试 {
operationList.add(builder.build());
ContentProviderResult [] RES = context.getContentResolver()applyBatch(ContactsContract.AUTHORITY,operationList)。
如果(RES [0] .Count之间的== 0){
// TODO然后使用Insert命令来代替!
}
}赶上(例外五){Log.d(fhksdsdj,e.toString()); }
}
解决方案
字符串selectArgs1 = Data.CONTACT_ID +=和+ Data.MIMETYPE +=;
的String [] selectArgs2 =新的String [] {的ContactID,vnd.android.cursor.item /笔记};
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(selectArgs1,selectArgs2)
.withValue(ContactsContract.CommonDataKinds.Note.NOTE,hello@hi.com)
。建立());
试试这个code ...
Im using the new'ish API to insert/update contacts on my phone and I'm using this method to updates them..
String selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Note.CONTENT_ITEM_TYPE + "'" + " AND " + Email.TYPE + "=?";
String[] selectArgs2 = new String[]{contactId, String.valueOf(Email.TYPE_OTHER)};
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(selectArgs1, selectArgs2)
.withValue(Note.Note, "hello@hi.com")
.build());
This is all working fine, except for when i get to updating a Note. There isn't a Note.Type_1
or anything like that, so i don't know what to put in the selectArgs1 and selectArgs2 in replace of Email.TYPE
and String.valueOf(Email.TYPE_OTHER)
Any help would be much apreciated. Thanks! :)
[Edit]
public static void updateContact(Context c, int recordId, String key, String value) {
context = c;
if (database == null) database = new SavedContactsDatabase(context);
ArrayList<ContentProviderOperation> operationList = new ArrayList<ContentProviderOperation>();
ContentProviderOperation.Builder builder = ContentProviderOperation.newUpdate(Data.CONTENT_URI);
String contactId = String.valueOf(recordId);
String selectArgs1 = "";
String[] selectArgs2 = null;
String type = "";
String subkey = "";
if (key.contains(":")) {
String[] split = key.split(":");
key = split[0];
type = split[1];
if (split.length == 3) subkey = split[2];
}
if (key.equals("Email")) {
if (type.equals("Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(Email.TYPE_HOME)};
} else if (type.equals("Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(Email.TYPE_WORK)};
} else if (type.equals("Mobile")) {
selectArgs2 = new String[]{contactId, String.valueOf(Email.TYPE_MOBILE)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Email.CONTENT_ITEM_TYPE + "'" + " AND " + Email.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Email.DATA1, value);
}
if (key.equals("Nickname")) {
if (type.equals("Default")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_DEFAULT)};
} else if (type.equals("Other Names")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_OTHER_NAME)};
} else if (type.equals("Maiden Name")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_MAINDEN_NAME)};
} else if (type.equals("Short Name")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_SHORT_NAME)};
} else if (type.equals("Initials")) {
selectArgs2 = new String[]{contactId, String.valueOf(Nickname.TYPE_INITIALS)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Nickname.CONTENT_ITEM_TYPE + "'" + " AND " + Nickname.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Nickname.NAME, value);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////
if (key.equals("Note")) {
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Note.CONTENT_ITEM_TYPE + "'";
selectArgs2 = new String[]{contactId, "vnd.android.cursor.item/note"};
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Note.NOTE, "hello@hi.com");
}
/////////////////////////////////////////////////////////////////////////////////////////////////////
if (key.equals("Organization")) {
String data = "";
if (type.equals("Company")) {
data = Organization.COMPANY;
} else if (type.equals("Title")) {
data = Organization.TITLE;
} else if (type.equals("Department")) {
data = Organization.DEPARTMENT;
} else if (type.equals("Job Descripiton")) {
data = Organization.JOB_DESCRIPTION;
} else if (type.equals("Symbol")) {
data = Organization.SYMBOL;
} else if (type.equals("Phonetic Name")) {
data = Organization.PHONETIC_NAME;
} else if (type.equals("Office Location")) {
data = Organization.OFFICE_LOCATION;
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Organization.CONTENT_ITEM_TYPE + "'" + " AND " + Organization.TYPE + "=?";
selectArgs2 = new String[]{contactId, String.valueOf(Organization.TYPE_WORK)};
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(data, value);
}
if (key.equals("Phone")) {
if (type.equals("Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_HOME)};
} else if (type.equals("Mobile")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_MOBILE)};
} else if (type.equals("Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_WORK)};
} else if (type.equals("Fax Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_FAX_WORK)};
} else if (type.equals("Fax Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_FAX_HOME)};
} else if (type.equals("Pager")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_PAGER)};
} else if (type.equals("Other")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_OTHER)};
} else if (type.equals("Callback")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_CALLBACK)};
} else if (type.equals("Car")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_CAR)};
} else if (type.equals("Company Main")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_COMPANY_MAIN)};
} else if (type.equals("ISDN")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_ISDN)};
} else if (type.equals("Main")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_MAIN)};
} else if (type.equals("Other Fax")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_OTHER_FAX)};
} else if (type.equals("Radio")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_RADIO)};
} else if (type.equals("Telex")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_TELEX)};
} else if (type.equals("TTY TDD")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_TTY_TDD)};
} else if (type.equals("Work Mobile")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_WORK_MOBILE)};
} else if (type.equals("Work Pager")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_WORK_PAGER)};
} else if (type.equals("Assistant")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_ASSISTANT)};
} else if (type.equals("MMS")) {
selectArgs2 = new String[]{contactId, String.valueOf(Phone.TYPE_MMS)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Phone.CONTENT_ITEM_TYPE + "'" + " AND " + Phone.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Phone.NUMBER, value);
}
//TODO Relation?
//////////////////////////////////////////////////////////////////////////////////////
if (key.equals("Name")) {
String data = "";
if (type.equals("Display Name")) {
data = StructuredName.DISPLAY_NAME;
} else if (type.equals("Given Name")) {
data = StructuredName.GIVEN_NAME;
} else if (type.equals("Family Name")) {
data = StructuredName.FAMILY_NAME;
} else if (type.equals("Prefix")) {
data = StructuredName.PREFIX;
} else if (type.equals("Middle Name")) {
data = StructuredName.MIDDLE_NAME;
} else if (type.equals("Suffix")) {
data = StructuredName.SUFFIX;
} else if (type.equals("Phonetic Given Name")) {
data = StructuredName.PHONETIC_GIVEN_NAME;
} else if (type.equals("Phonetic Middle Name")) {
data = StructuredName.PHONETIC_MIDDLE_NAME;
} else if (type.equals("Phonetic Family Name")) {
data = StructuredName.PHONETIC_FAMILY_NAME;
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + StructuredName.CONTENT_ITEM_TYPE + "'" + " AND " + StructuredName.MIMETYPE + "=?";
selectArgs2 = new String[]{contactId, String.valueOf(StructuredName.MIMETYPE)};
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(data, value);
}
////////////////////////////////////////////////////////////////////////////////////////
if (key.equals("Address")) {
String data = "";
if (type.equals("Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(CommonDataKinds.StructuredPostal.TYPE_HOME)};
} else if (type.equals("Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(CommonDataKinds.StructuredPostal.TYPE_WORK)};
} else if (type.equals("Other")) {
selectArgs2 = new String[]{contactId, String.valueOf(CommonDataKinds.StructuredPostal.TYPE_OTHER)};
}
if (subkey.equals("Street")) {
data = CommonDataKinds.StructuredPostal.STREET;
} else if (subkey.equals("PO Box")) {
data = CommonDataKinds.StructuredPostal.POBOX;
} else if (subkey.equals("Neighbourhood")) {
data = CommonDataKinds.StructuredPostal.NEIGHBORHOOD;
} else if (subkey.equals("City")) {
data = CommonDataKinds.StructuredPostal.CITY;
} else if (subkey.equals("Region")) {
data = CommonDataKinds.StructuredPostal.REGION;
} else if (subkey.equals("Postcode")) {
data = CommonDataKinds.StructuredPostal.POSTCODE;
} else if (subkey.equals("Country")) {
data = CommonDataKinds.StructuredPostal.COUNTRY;
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + CommonDataKinds.StructuredPostal.CONTENT_ITEM_TYPE + "'" + " AND " + CommonDataKinds.StructuredPostal.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(data, value);
}
if (key.equals("Website")) {
if (type.equals("Homepage")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_HOMEPAGE)};
} else if (type.equals("Blog")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_BLOG)};
} else if (type.equals("Profile")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_PROFILE)};
} else if (type.equals("Home")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_HOME)};
} else if (type.equals("Work")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_WORK)};
} else if (type.equals("FTP")) {
selectArgs2 = new String[]{contactId, String.valueOf(Website.TYPE_FTP)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Website.CONTENT_ITEM_TYPE + "'" + " AND " + Website.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Website.URL, value);
}
if (key.equals("Event")) {
if (type.equals("Anniversary")) {
selectArgs2 = new String[]{contactId, String.valueOf(Event.TYPE_ANNIVERSARY)};
} else if (type.equals("Birthday")) {
selectArgs2 = new String[]{contactId, String.valueOf(Event.TYPE_BIRTHDAY)};
}
selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" + Event.CONTENT_ITEM_TYPE + "'" + " AND " + Event.TYPE + "=?";
builder.withSelection(selectArgs1, selectArgs2);
builder.withValue(Event.START_DATE, value);
}
/*
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(Data.RAW_CONTACT_ID + "=?", new String[] {sdf})
.withValue(Email.DATA1, "work.hi.com")
.withValue(Email.TYPE, Email.TYPE_WORK)
.build());
*/
/*
String selectPhone = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "='" +
Email.CONTENT_ITEM_TYPE + "'" + " AND " + Email.TYPE + "=?";
String[] phoneArgs = new String[]{contactId, String.valueOf(Email.TYPE_OTHER)};
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(selectPhone, phoneArgs)
.withValue(Email.DATA1, "hello@hi.comm")
.build());
*/
try {
operationList.add(builder.build());
ContentProviderResult[] res = context.getContentResolver().applyBatch(ContactsContract.AUTHORITY, operationList);
if (res[0].count == 0) {
//TODO Then Use the Insert Command Instead!
}
} catch (Exception e) { Log.d("fhksdsdj", e.toString()); }
}
解决方案
String selectArgs1 = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + "= ? ";
String[] selectArgs2 = new String[]{contactId, "vnd.android.cursor.item/note"};
operationList.add(ContentProviderOperation.newUpdate(Data.CONTENT_URI)
.withSelection(selectArgs1, selectArgs2)
.withValue(ContactsContract.CommonDataKinds.Note.NOTE, "hello@hi.com")
.build());
try this code...