查询Android联系人以获取帐户类型和帐户名称

查询Android联系人以获取帐户类型和帐户名称,android,android-contacts,contactscontract,rawcontacts,Android,Android Contacts,Contactscontract,Rawcontacts,我能够获得联系人列表及其基本信息,如:姓名。电话、电子邮件、即时消息、便笺、组织,用于备份目的,使用Contacts Contacts.Contacts.CONTENT\u URI获取联系人列表和不同信息类型的其他特定URI 为了完全恢复所有信息,我还需要两个字段: 联系人contract.raw contacts.ACCOUNT\u类型 Contacts contract.raw contacts.ACCOUNT\u NAME 有谁能告诉我如何从ContactsContacts.Contact

我能够获得联系人列表及其基本信息,如:姓名。电话、电子邮件、即时消息、便笺、组织,用于备份目的,使用
Contacts Contacts.Contacts.CONTENT\u URI
获取联系人列表和不同信息类型的其他特定URI

为了完全恢复所有信息,我还需要两个字段:

联系人contract.raw contacts.ACCOUNT\u类型

Contacts contract.raw contacts.ACCOUNT\u NAME

有谁能告诉我如何从ContactsContacts.Contacts.CONTENT\u URI获取此信息


谢谢

如果您正在使用contactID列查找帐户信息,则上述答案非常完美。但是,信息通常是使用rawContactID存储的。因此,如果您想要访问原始联系人id的帐户信息,那么您可以使用下面的方法。
public ContactAccount getContactAccount(Long id,ContentResolver contentResolver) {

        ContactAccount account = null;

        Cursor cursor = null;
        try {

             cursor = contentResolver.query(ContactsContract.RawContacts.CONTENT_URI,
                     new String[]{ContactsContract.RawContacts.ACCOUNT_NAME, ContactsContract.RawContacts.ACCOUNT_TYPE},
                     ContactsContract.RawContacts.CONTACT_ID +"=?",
                     new String[]{String.valueOf(id)},
                     null);

            if (cursor != null && cursor.getCount() >0)
            {
                cursor.moveToFirst();
                account = new ContactAccount();
                account.setAccountName(cursor.getString(cursor.getColumnIndex(ContactsContract.RawContacts.ACCOUNT_NAME)));
                account.setAccountType(cursor.getString(cursor.getColumnIndex(ContactsContract.RawContacts.ACCOUNT_TYPE)));
                cursor.close();
            }
        } catch (Exception e) {
            Utils.log(this.getClass().getName(), e.getMessage()); 
        } finally{
          cursor.close();
        }

        return(account);
    }
关键的区别在于我使用的是rawContacts表中的_ID列。这映射到您将在其他表中看到的rawContactID

public int   updateAccountInfoForContactData(String rawContactID) {
    int    accountPos    = 0;

    Cursor cursor        = null;
    String accountName   = null;
    String accountType   = null;
    Uri rawContactUri      = ContactsContract.RawContacts.CONTENT_URI;
    String[] syncColumns   = new String[] {
                                            ContactsContract.RawContacts.ACCOUNT_NAME,
                                            ContactsContract.RawContacts.ACCOUNT_TYPE,
                                    };
    String   whereClause   = ContactsContract.RawContacts._ID +"=?";
    String[] whereParams   = new String[]{String.valueOf(rawContactID)};
    //Uri rawContactUri = ContentUris.withAppendedId(ContactsContract.RawContacts.CONTENT_URI, longContactID);
    try {
        cursor = mContext.getContentResolver().query(
                rawContactUri,
                syncColumns,
                whereClause,
                whereParams,
                null);

        if (cursor != null && cursor.getCount() >0)
        {
            cursor.moveToFirst();
            if(cursor.getColumnIndex(ContactsContract.RawContacts.ACCOUNT_NAME) >= 0) {
                accountName = cursor.getString(cursor.getColumnIndex(ContactsContract.RawContacts.ACCOUNT_NAME));
            }
            if(cursor.getColumnIndex(ContactsContract.RawContacts.ACCOUNT_TYPE) >= 0) {
                accountType = cursor.getString(cursor.getColumnIndex(ContactsContract.RawContacts.ACCOUNT_TYPE));
            }
            cursor.close();
            cursor = null;

        }
    } catch (Exception e) {
        Log.d(TAG, "getting account info failed");
    } finally{
        if(cursor != null) {
            cursor.close();
        }
        cursor = null;
    }

    return(accountPos);
}