我正在使用以下查询检索最近的短信息/彩信对话列表:
String[] columns={"type", "address", "date", "body", "conversation_id"};
Cursor cursor=context.getContentResolver().query(Uri.parse("content://mms-sms/conversations"), columns, null, null, "date desc");
有谁能告诉我如何在同一个查询中同时查询联系人姓名吗?特别是字段
ContactsContract.PhoneLookup.DISPLAY_NAME
?我的意思是,我知道如何在单独的查询中获取这些字段,但我需要在与对话相同的查询中获取它。
最佳答案
试试这个:
Log.i(TAG,"load_contact for "+Phone_numb);
Uri uri = Uri.withAppendedPath(ContactsContract.PhoneLookup.CONTENT_FILTER_URI, Uri.encode(Phone_numb));
String name = "?";
ContentResolver contentResolver = getContentResolver();
Cursor contactLookup = contentResolver.query(uri, new String[] {BaseColumns._ID,
ContactsContract.PhoneLookup.DISPLAY_NAME }, null, null, null);
try {
if (contactLookup != null && contactLookup.getCount() > 0) {
contactLookup.moveToNext();
name = contactLookup.getString(contactLookup.getColumnIndex(ContactsContract.Data.DISPLAY_NAME));
}
else
{
return Phone_numb;
}
} finally {
if (contactLookup != null) {
contactLookup.close();
}
}