zoukankan      html  css  js  c++  java
  • 通过ContactID来查找联系人信息

    首先查找全部的RawContact表,得到一个对应的ContactId,通过这个ContactId查找Contact表,获取该联系人的所有信息,删除的联系人信息应该在RawContact表中不会删除, 只是删除了Contact表里面的数据,所以如果在Contact表中找不到ContactId对应的数据,我就可以判断该联系人被删除了.


            Cursor cursor = getContentResolver().query(

            ContactsContract.RawContacts.CONTENT_URI, null, null, null, null);

            while (cursor.moveToNext()) {
                String rawContactId = cursor.getString(cursor
                        .getColumnIndex(ContactsContract.RawContacts._ID));
                Log.i("RAW_CONTACTS _ID", rawContactId);

                // 得到rawcontact对应的contactId

                String contactId = cursor.getString(cursor
                        .getColumnIndex(ContactsContract.RawContacts.CONTACT_ID));
                Log.i("RAW_CONTACTS CONTACT_ID", contactId);

                // 同步contactId查询contact表,添加一个selector值进行过滤

                Cursor c = getContentResolver().query(
                        ContactsContract.Contacts.CONTENT_URI, null,
                        ContactsContract.Contacts._ID + " =  " + contactId, null,
                        null);
                while (c.moveToNext()) {
                    String dn = c
                            .getString(c
                                    .getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
                    Log.v("DISPLAY NAME", dn);
                }

                String deleted = cursor.getString(cursor
                        .getColumnIndex(ContactsContract.RawContacts.DELETED));

                Log.i("RAW_CONTACTS DELETED", deleted);
            }
  • 相关阅读:
    python类库31[正则表达式匹配实例]
    Mysql百万级数据迁移实战笔记
    面试官:一千万数据,怎么快速查询?
    为什么MySQL不建议使用NULL作为列默认值?
    Redis各个数据类型最大存储量
    Rabbitmq延迟队列实现定时任务
    PHPstorm批量修改文件换行符CRLF为LF
    使用SeasLog打造高性能日志系统
    协程编程注意事项
    Rabbitmq 安装过程中常见问题(亲测可行)
  • 原文地址:https://www.cnblogs.com/kakafra/p/2709011.html
Copyright © 2011-2022 走看看