CursorLoader在联系人中的应用,以及联系人应用中,多表联合查询

联系人应用中,对数据的加载都是利用CursorLoader来完成的。

联系人主列表:

DefaultContactBrowseListFragment   -->  DefaultContactListAdapter --> configureLoader --> configureSelection


联系人常见的三大picker及其adapter,以及这些adapter是如何配置cursorloader的:

ContactPickerFragment              -->  DefaultContactListAdapter  --> configureLoader --> configureSelection

PhoneFavoritePickerFragment   -->  ContactTileLoaderListener  --> onCreateLoader --> ContactTileLoaderFactory  --> createFrequentPhoneOnlyLoader

GroupPickerFragment                -->  mGroupLoaderListener       --> onCreateLoader --> PickerGroupListLoader


在对cursorloader进行配置的过程中,可能会涉及到多表查询。一般可以将查询条件放在selection里。比如在DefaultContactListAdapter 中的configureSelection,加入如下代码:

        String groupid = getGroupId();
        if (groupid != null) {
            String selectionExtra = "_id not in (select contact_id from view_data where data1 = '" + groupid + "') ";
            if (selection.length() != 0) {
                selection.append(" AND " + selectionExtra);
            }
            else {
                selection.append(selectionExtra);
            }
        }

DefaultContactListAdapter里query的uri是contact表,而我们的查询条件需要查询view_data。


另外,PhoneFavoritePickerFragment (ContactTileLoaderFactory)表面上也是在query contact表,但是看了contactsprovider2.java的代码才知道,在query_local()中,对于CONTACTS_STREQUENT的查询,会自动转化成对view_data的查询。这一点需要注意。

你可能感兴趣的:(CursorLoader在联系人中的应用,以及联系人应用中,多表联合查询)