gpt4 book ai didi

android - ContactsContract.Data 隐式连接列不起作用?

转载 作者:行者123 更新时间:2023-11-30 04:15:23 27 4
gpt4 key购买 nike

很抱歉,如果这可能是一个重复的问题,我整个晚上都在努力解决这个问题,而且我似乎找不到其他可能对此有所启发的帖子,所以我希望多几双眼睛可能会发现一些东西。

我对 ContactsContract.Data 的 API 文档有这样的印象当您指定某些字段时,该库会施展魔法并在后台为您执行隐式连接。

似乎对我不起作用。

import android.provider.ContactsContract.CommonDataKinds.Phone;

private Cursor getContacts()
{
// Run query
Uri uri = Phone.CONTENT_URI;
String[] projection = new String[] {
Phone.DISPLAY_NAME,
Phone.NUMBER,
Phone.CONTENT_ITEM_TYPE,
Phone.HAS_PHONE_NUMBER,
Phone.IN_VISIBLE_GROUP
};
String selection = Phone.HAS_PHONE_NUMBER + " = '1' AND " + Phone.IN_VISIBLE_GROUP + " = '1'";
String[] selectionArgs = null;
String sortOrder = Phone.DISPLAY_NAME + " COLLATE LOCALIZED ASC";
return getContentResolver().query(uri, projection, selection, selectionArgs, sortOrder);
}

当它运行时,它死于:

java.lang.IllegalArgumentException: Invalid column vnd.android.cursor.item/phone_v2

来自 ContactsContract.CommonDataKinds.Phone 的文档它明确指出:

You can use all columns defined for ContactsContract.Data as well as the following aliases.

我错过了什么?

最佳答案

Phone.CONTENT_ITEM_TYPE 是您的问题。这不是列名,而是 Data.MIME_TYPE 设置的常量。将它从您的投影中移除,它应该没问题。

关于android - ContactsContract.Data 隐式连接列不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10108199/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com