【发布时间】:2018-08-07 02:51:07
【问题描述】:
如何在一个查询中设置ContactsContract.CommonDataKinds.Email 和ContactsContract.CommonDataKinds.Phone 的查询并获取ID、姓名、电话号码和电子邮件...?
如下代码:
private void getContactList() {
String id = "";
String name = "";
String phoneNo = "";
String mail = "";
ContentResolver cr = getContentResolver();
Cursor cur = cr.query(ContactsContract.Contacts.CONTENT_URI,
null, null, null, null);
if ((cur != null ? cur.getCount() : 0) > 0) {
while (cur != null && cur.moveToNext()) {
id = cur.getString(cur.getColumnIndex(ContactsContract.Contacts._ID));
name = cur.getString(cur.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
//if (cur.getInt(cur.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER)) > 0) {
Cursor pCur = cr.query(
ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
null,
ContactsContract.CommonDataKinds.Phone.CONTACT_ID + " = ?",
new String[]{id}, null);
Cursor eCur = cr.query(
ContactsContract.CommonDataKinds.Email.CONTENT_URI,
null,
ContactsContract.CommonDataKinds.Email.CONTACT_ID + " = ?",
new String[]{id}, null);
if (pCur != null) {
while (pCur.moveToNext()) {
phoneNo = pCur.getString(pCur.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
if (phoneNo != null && !TextUtils.isEmpty(phoneNo)) {
//Log.i("ASDASDASDASDD", "id: " + id);
Log.i("ASDASDASDASDD", "Name: " + name);
Log.i("ASDASDASDASDD", "Phone Number: " + phoneNo);
Log.i("ASDASDASDASDD", "email: ");
} else {
phoneNo = "";
}
}
pCur.close();
} else {
phoneNo = "";
}
if (eCur != null) {
while (eCur.moveToNext()) {
mail = eCur.getString(eCur.getColumnIndex(ContactsContract.CommonDataKinds.Email.DATA));
if (mail != null && !TextUtils.isEmpty(mail)) {
//Log.i("ASDASDASDASDD", "id: " + id);
Log.i("ASDASDASDASDD", "Name: " + name);
Log.i("ASDASDASDASDD", "Phone Number: " + phoneNo);
Log.i("ASDASDASDASDD", "email: " + mail);
} else {
mail = "";
}
}
eCur.close();
} else {
mail = "";
}
}
//}
}
if (cur != null) {
cur.close();
}
}
我需要同时拥有电话、姓名、身份证、电子邮件和...。
【问题讨论】:
标签: android android-sqlite android-contacts android-cursor contactscontract