【问题标题】:How To Remove Unique Values From a Cursor如何从光标中删除唯一值
【发布时间】:2019-12-28 13:42:30
【问题描述】:

我正在开发一个应用程序,我只应该向用户显示重复的电话联系人,以便他们可以删除重复项。 Duplicates

到目前为止,我能够使用以下代码显示所有联系人:

主要活动:

private void showContacts() {
Cursor cursor = ContactHelper.getContactCursor(getContentResolver(),"");
String[] fields = new String[]{ContactsContract.Data.DISPLAY_NAME};

adapter =new SimpleCursorAdapter(this,android.R.layout.simple_list_item_multiple_choice,cursor,fields,new  int[]{android.R.id.text1});
listView.setAdapter(adapter);
adapter.notifyDataSetChanged(); }

ContactHelper.GetContactsCursor 函数:

public static Cursor getContactCursor(ContentResolver contactHelper,
                                      String startsWith) {

    String[] projection = { ContactsContract.CommonDataKinds.Phone._ID,
            ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME,
            ContactsContract.CommonDataKinds.Phone.NUMBER };
    Cursor cur = null;

    try {
        if (startsWith != null && !startsWith.equals("")) {
            cur = contactHelper.query(
                    ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
                    projection,
                    ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                            + " like \"" + startsWith + "%\"", null,
                    ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                            + " ASC");
        } else {
            cur = contactHelper.query(
                    ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
                    projection, null, null,
                    ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                            + " ASC");
        }
        cur.moveToFirst();
    } catch (Exception e) {
        e.printStackTrace();
    }

    return cur;
}

private static long getContactID(ContentResolver contactHelper,
                                 String number) {
    Uri contactUri = Uri.withAppendedPath(ContactsContract.PhoneLookup.CONTENT_FILTER_URI,
            Uri.encode(number));

    String[] projection = { ContactsContract.PhoneLookup._ID };
    Cursor cursor = null;

    try {
        cursor = contactHelper.query(contactUri, projection, null, null,
                null);

        if (cursor.moveToFirst()) {
            int personID = cursor.getColumnIndex(ContactsContract.PhoneLookup._ID);
            return cursor.getLong(personID);
        }

        return -1;
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        if (cursor != null) {
            cursor.close();
            cursor = null;
        }
    }

    return -1; }

如何过滤光标中的唯一值?并且尽可能只根据电话号码保留重复的联系人?

【问题讨论】:

    标签: java android cursor android-contacts


    【解决方案1】:

    也许这会起作用

        try {
            if (startsWith != null && !startsWith.equals("")) {
                cur = contactHelper.query(
                        ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
                        projection,
                        ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                                + " like \"" + startsWith + "%\""
                                + " AND "
                                + ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                                + " IN (SELECT " + ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                                + " as name FROM view_data GROUP BY " +ContactsContract.CommonDataKinds.Phone.NUMBER + " HAVING COUNT(name)>1)",
                        null,
                        ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                                + " ASC");
            } else {
                cur = contactHelper.query(
                        ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
                        projection,
                        ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                                + " IN (SELECT " + ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                                + " as name FROM view_data GROUP BY " +ContactsContract.CommonDataKinds.Phone.NUMBER + " HAVING COUNT(name)>1)",
                        null,
                        ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                                + " ASC");
            }
            cur.moveToFirst();
        } catch (Exception e) {
            e.printStackTrace();
        }
    

    【讨论】:

      猜你喜欢
      • 2022-01-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-02-28
      • 2018-11-05
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多