【问题标题】:Use cursor loader for multiple data sources对多个数据源使用游标加载器
【发布时间】:2019-05-27 17:01:52
【问题描述】:

我的代码使用联系人姓名作为选择从 Android 获取联系人信息。但是,数据源(我猜是 ContactsContract.Contacts)并没有我需要的有关联系人的所有信息。我看到联系信息分为几个表(ContactsContract.CommonDataKinds.StructuredName、ContactsContract.CommonDataKinds.Phone 等)。我还注意到所有这些来源都可以访问 LOOKUP_KEY 字段。它唯一地标识一个联系人。我想知道是否有办法使用 LOOKUP_KEY 对这些数据源执行连接。

下面,我目前为单个数据源设置投影和选择,并使用游标加载器异步查询它。有没有办法使用 LOOKUP_KEY 一次搜索多个数据源?

private static final String[] CONTACT_PROJECTION = {
        ContactsContract.Contacts._ID,
        ContactsContract.Contacts.LOOKUP_KEY,
        ContactsContract.Contacts.DISPLAY_NAME_PRIMARY,
        ContactsContract.Contacts.HAS_PHONE_NUMBER
};

private static final String CONTACT_SELECTION = ContactsContract.Contacts.DISPLAY_NAME_PRIMARY
        + " LIKE ?";

public static Loader<Cursor> getContactLoader(Context applicationContext, String searchString) {
    String[] selectionArgs = new String[1];
    selectionArgs[0] = "%" + searchString + "%";
    return new CursorLoader(
            applicationContext,
            ContactsContract.Contacts.CONTENT_URI,
            CONTACT_PROJECTION,
            CONTACT_SELECTION,
            selectionArgs,
            null
    );
}

【问题讨论】:

    标签: java android android-contacts


    【解决方案1】:

    所有联系人的所有信息都分组在别名表中,这些别名表实际上存储在一个名为 Data 的大表中,因此您可以简单地查询该表以获取与特定联系人相关的所有信息(您可以使用 CONTACT_ID , 没必要去纠缠更成问题的LOOKUP_URI),像这样:

    public void getContactInfo(long contactId) {
    
        Uri uri = Data.CONTENT_URI;
    
        String[] projection = new String[]{
                Data.CONTACT_ID,
                Data.DISPLAY_NAME,
                Data.MIMETYPE,
                Data.DATA1}; // you can get additional info if needed in Data.DATA2, DATA3, etc.
    
        // get all relevant info about the contact
        String selection = Data.CONTACT_ID + "=? AND " + Data.MIMETYPE + " IN (?,?,?,?)"; // you can add more question marks if you need more MIMETYPES
        String[] selectionArgs = new String[]{String.valueOf(contactId), Phone.CONTENT_ITEM_TYPE, Email.CONTENT_ITEM_TYPE, Event.CONTENT_ITEM_TYPE, StructuredPostal.CONTENT_ITEM_TYPE};
    
        Cursor cursor = getContentResolver().query(uri, projection, selection, selectionArgs, null);
    
        while (cursor.moveToNext()) {
            String name = cursor.getString(1);
            String mimetype = cursor.getString(2);
            String data = cursor.getString(3);
    
            // use the mimetype to figure out what kind of info is in this row
    
            Log.i("Contact Info", contactId + "=> " + name + " - " + mimetype + ": " + data);
        }
        cursor.close();
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-05-21
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多