我正在尝试将联系人插入Android联系人数据库。 我发现了一些教程(我并不完全理解),我基本上从Android SDK的“ContactManager”示例代码中复制了这些方法。
我使用此方法添加新的原始联系人:
public void createContact(String name, String phone, String mobile, String email) {
ContentResolver cr = mContext.getContentResolver();
ArrayList<ContentProviderOperation> ops = new ArrayList<ContentProviderOperation>();
ops.add(ContentProviderOperation.newInsert(ContactsContract.RawContacts.CONTENT_URI)
.withValue(ContactsContract.RawContacts.ACCOUNT_TYPE, mAccount.type)
.withValue(ContactsContract.RawContacts.ACCOUNT_NAME, mAccount.name).build());
ops.add(ContentProviderOperation
.newInsert(ContactsContract.Data.CONTENT_URI)
.withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, 0)
.withValue(ContactsContract.Data.MIMETYPE,
ContactsContract.CommonDataKinds.StructuredName.CONTENT_ITEM_TYPE)
.withValue(ContactsContract.CommonDataKinds.StructuredName.DISPLAY_NAME, name)
.build());
ops.add(ContentProviderOperation
.newInsert(ContactsContract.Data.CONTENT_URI)
.withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, 0)
.withValue(ContactsContract.Data.MIMETYPE,
ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE)
.withValue(ContactsContract.CommonDataKinds.Phone.DATA10, phone)
.withValue(ContactsContract.CommonDataKinds.Phone.TYPE,
ContactsContract.CommonDataKinds.Phone.TYPE_WORK).build());
ops.add(ContentProviderOperation
.newInsert(ContactsContract.Data.CONTENT_URI)
.withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, 0)
.withValue(ContactsContract.Data.MIMETYPE,
ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE)
.withValue(ContactsContract.CommonDataKinds.Phone.DATA11, mobile)
.withValue(ContactsContract.CommonDataKinds.Phone.TYPE,
ContactsContract.CommonDataKinds.Phone.TYPE_WORK_MOBILE).build());
ops.add(ContentProviderOperation
.newInsert(ContactsContract.Groups.CONTENT_URI)
.withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, 0)
.withValue(ContactsContract.Data.MIMETYPE,
ContactsContract.CommonDataKinds.Email.CONTENT_ITEM_TYPE)
.withValue(ContactsContract.CommonDataKinds.Email.DATA, email)
.withValue(ContactsContract.CommonDataKinds.Email.TYPE,
ContactsContract.CommonDataKinds.Email.TYPE_WORK).build());
正如您所见,我正在尝试插入一个名称(我稍后会插入单独的姓名和姓氏),办公室号码和手机号码以及电子邮件。
当我运行代码时,我收到此错误:
插入脏时出错= 1 mimetype = vnd.android.cursor.item / email_v2 data2 = 2 data1 =foo@foo.com account_type = vnd.sec.contact.phone account_name = vnd.sec.contact.phone raw_contact_id = 2 android.database.sqlite.SQLiteException:表组没有名为mimetype:的列,同时编译:INSERT INTO组(dirty,mimetype,data2,data1,account_type,account_name,raw_contact_id)VALUES(?,?,?,?,?, ?,?);
似乎它正在尝试将一些数据插入到组数据库中,尽管我并不理解为什么。
当我运行ContactManager示例应用程序时,它运行正常,除了我使用此应用程序添加的联系人没有出现在Android电话簿中,由于某种原因它们被标记为不可见。
有没有人知道发生了什么?
谢谢!
答案 0 :(得分:4)
您收到该错误是因为您尝试在“组”表中插入电子邮件地址。 (URI应为ContactsContract.Data.CONTENT_URI,而不是ContactsContract.Groups.CONTENT_URI)