通过不在android游标中工作的顺序

时间:2012-11-02 17:58:51

标签: android sqlite contacts android-contentprovider android-contacts

我有一些游标从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())代码

1 个答案:

答案 0 :(得分:1)

搞定了,

context.getContentResolver().query(CONTENT_URI, null, buf == null ? null : buf.toString(),args,Cons.ATTRIBUTES_NAME + " ASC");

在orederby字符串中没有空格,

=" "+  ContactsContract.Contacts.DISPLAY_NAME +" ASC"

从上面的行中删除属性名称前面的空格。