我有一些游标从Android检索联系人,一切正常,但问题是我无法使“按订单”条款工作。我尝试了很多东西,甚至使用“Upper
”和localized collection
子句,但似乎无法正常工作,我使用hashmap存储结果,所以我想我需要订购hashmap但我不想要这是因为顺序应该解决问题并节省处理时间。这是我的代码:
private Cursor getContacts() {
// Run query
Uri uri = ContactsContract.Contacts.CONTENT_URI;
String[] projection = new String[] { ContactsContract.Contacts._ID,
ContactsContract.Contacts.DISPLAY_NAME };
String selection = ContactsContract.Contacts.IN_VISIBLE_GROUP + " = '"
+ ("1") + "' AND "+ ContactsContract.Contacts.HAS_PHONE_NUMBER +"='" +("1")+"'";
String sortOrder =" "+ ContactsContract.Contacts.DISPLAY_NAME +" ASC";
CursorLoader query = new CursorLoader(context,uri, projection,
selection, null,
sortOrder);
return query.loadInBackground();
}
这是另一个按小组获取的信息:
contactInfo = new HashMap<String, ContactInfo>();
Cursor c = context.getApplicationContext().getContentResolver().query(ContactsContract.Data.CONTENT_URI
, new String[] {
ContactsContract.Contacts.DISPLAY_NAME, ContactsContract.Contacts._ID,
ContactsContract.RawContacts.CONTACT_ID },
ContactsContract.CommonDataKinds.GroupMembership.GROUP_ROW_ID + " = ?"+ " AND "
+ ContactsContract.Contacts.HAS_PHONE_NUMBER +"='" +("1")+"'",
new String[] { groupId },"UPPER("+ ContactsContract.Contacts.DISPLAY_NAME + ") ASC");
获取光标后我使用while(c.moveToNext())
代码
答案 0 :(得分:1)
搞定了,
context.getContentResolver().query(CONTENT_URI, null, buf == null ? null : buf.toString(),args,Cons.ATTRIBUTES_NAME + " ASC");
在orederby字符串中没有空格,
=" "+ ContactsContract.Contacts.DISPLAY_NAME +" ASC"
从上面的行中删除属性名称前面的空格。