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