3

我在查询电话簿联系人时遇到问题。我需要做的是获取同时输入了电话和电子邮件或属于特定类型的联系人列表。

基本上是这样的:

public static final String SELECTION =
    "("+ContactsContract.Contacts.HAS_PHONE_NUMBER +"='1') OR " + RawContacts.ACCOUNT_TYPE + "='" + Constants.ACCOUNT_TYPE + "'";

现在,问题是,在我的查询中使用RawContacts.ACCOUNT_TYPE它不存在。ContactsContract.Contacts.CONTENT_URI我猜我需要加入另一张桌子,但不知道该怎么做。

任何人都可以在这里帮助我吗?

4

2 回答 2

2

读取原始联系人以及与之关联的所有数据的最佳方法是使用ContactsContract.RawContacts.Entity目录。如果原始联系人有数据行,实体游标将为每个数据行包含一行。如果原始联系人没有数据行,则游标仍将包含一行包含原始联系人级别信息。

Uri rawContactUri = ContentUris.withAppendedId(RawContacts.CONTENT_URI, rawContactId);
 Uri entityUri = Uri.withAppendedPath(rawContactUri, Entity.CONTENT_DIRECTORY);
 Cursor c = getContentResolver().query(entityUri,
          new String[]{RawContacts.SOURCE_ID, Entity.DATA_ID, Entity.MIMETYPE, Entity.DATA1},
          null, null, null);
 try {
     while (c.moveToNext()) {
         String sourceId = c.getString(0);
         if (!c.isNull(1)) {
             String mimeType = c.getString(2);
             String data = c.getString(3);
             //decide here based on mimeType, see comment later
         }
     }
 } finally {
     c.close();
 }

您必须根据 mimeType 过滤结果

例如,如果 mimeType 为Phone.CONTENT_ITEM_TYPE,则该列DATA1存储电话号码,但如果数据类型为Email.CONTENT_ITEM_TYPE,则DATA1存储电子邮件地址。

这样您就不必使用HAS_PHONE_NUMBER,因为您将直接遍历这些项目。

于 2010-06-23T09:18:56.397 回答
1

也许您应该使用Email.CONTENT_URI它,因为它包含"vnd.android.cursor.item/email_v2"MIME 类型的所有数据记录,以及关联的原始联系人聚合联系人数据

于 2010-06-23T09:18:45.900 回答