查询Android联系人以获取ACCOUNT_TYPE和ACCOUNT_NAME

时间:2011-08-16 12:51:22

标签: android android-contacts contactscontract rawcontacts

我可以获取联系人列表及其基本信息,例如:姓名。用于备份目的的电话,电子邮件,即时消息,备注,组织,使用ContactsContract.Contacts.CONTENT_URI列出联系人列表以及其他针对不同信息类型的特定URI。

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

  

ContactsContract.RawContacts.ACCOUNT_TYPE

     

ContactsContract.RawContacts.ACCOUNT_NAME

任何人都可以指导我如何获取此信息,知道来自ContactsContract.Contacts.CONTENT_URI的联系人ID?

谢谢

2 个答案:

答案 0 :(得分:10)

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);
    }

答案 1 :(得分:0)

如果您正在使用contactID列查找帐户信息,则以上答案非常理想。但是,通常信息是使用rawContactID存储的。因此,如果要访问原始联系人ID的帐户信息,则可以在下面使用此方法。 关键区别在于我正在使用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);
}