查询指定组中的联系人成员



我需要在android联系人中获取特定组的成员。

我有联系人组的名字和他们的身份证

有人能告诉我如何查询特定群组中成员的联系人提供商吗?

试试这个方法:

private Cursor getContacts(String groupID) {
   Uri uri = ContactsContract.Data.CONTENT_URI;
   String[] projection = new String[] {
       ContactsContract.Contacts._ID,
       ContactsContract.Data.CONTACT_ID,
       ContactsContract.Data.DISPLAY_NAME
   };
   String selection = null;
   String[] selectionArgs = null;
   if(groupID != null && !"".equals(groupID)) {
       selection = ContactsContract.CommonDataKinds.GroupMembership.GROUP_ROW_ID
                   + " = ?";
       selectionArgs = new String[] { groupID };
   }
   else
       selection = "1) GROUP BY (" + ContactsContract.Data.CONTACT_ID;
       String sortOrder = ContactsContract.Contacts.DISPLAY_NAME 
                          + " COLLATE LOCALIZED ASC ";
       return getContentResolver().query(uri, projection, 
                                         selection, selectionArgs, sortOrder);
}

这适用于Android 2.3.3及更低版本,但不适用于Android 4+,我目前不知道为什么。

UPD

在Android 4+中,向SQL查询添加自定义字符串参数"GROUP BY"是被拒绝的,所以我找到了这个解决方法:

private Cursor getContacts(String groupID) {
    Uri uri = ContactsContract.Data.CONTENT_URI;
    String[] projection = new String[] {
            ContactsContract.Contacts._ID,
            ContactsContract.Data.CONTACT_ID,
            ContactsContract.Data.DISPLAY_NAME
    };
    String selection = null;
    String[] selectionArgs = null;
    if(groupID != null && !"".equals(groupID)) {
        selection = ContactsContract.CommonDataKinds.GroupMembership.GROUP_ROW_ID 
                        + " = ?";
        selectionArgs = new String[] { groupID };
    }
    String sortOrder = ContactsContract.Contacts.DISPLAY_NAME 
                        + " COLLATE LOCALIZED ASC ";
    Cursor cursor = getContentResolver().query(uri, projection, 
                                          selection, selectionArgs, sortOrder); 
    MatrixCursor result = new MatrixCursor(projection);
    Set<Long> seen = new HashSet<Long>();
    while (cursor.moveToNext()) {
        long raw = cursor.getLong(1);
        if (!seen.contains(raw)) {
            seen.add(raw);
            result.addRow(new Object[] { cursor.getLong(0), 
                             cursor.getLong(1), cursor.getString(2) });
        }
    }
    return result;

最新更新