Android Q(SDK 29)上的“ContentResolver无效列错误”
创始人
2024-08-15 03:30:21
0

在Android Q(SDK 29)上,如果你在使用ContentResolver查询数据时遇到“无效列错误”(Invalid column error),这可能是因为该列不存在或者列名被更改了。

解决方法如下:

  1. 确保你查询的表中确实存在该列。你可以通过查看数据库模式或者表结构来确认。

  2. 如果列名被更改了,你需要更新你的查询语句中的列名。确保列名的大小写和拼写与表中的列名完全匹配。

下面是一个使用ContentResolver查询数据的示例代码:

String[] projection = {
    ContactsContract.Contacts._ID,
    ContactsContract.Contacts.DISPLAY_NAME
};

Uri uri = ContactsContract.Contacts.CONTENT_URI;

Cursor cursor = getContentResolver().query(uri, projection, null, null, null);

if (cursor != null && cursor.moveToFirst()) {
    int idColumnIndex = cursor.getColumnIndex(ContactsContract.Contacts._ID);
    int nameColumnIndex = cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME);

    do {
        String contactId = cursor.getString(idColumnIndex);
        String contactName = cursor.getString(nameColumnIndex);

        // 处理查询结果
        Log.d(TAG, "Contact ID: " + contactId + ", Name: " + contactName);
    } while (cursor.moveToNext());
}

if (cursor != null) {
    cursor.close();
}

在这个示例中,我们查询了系统联系人的ID和显示名。你可以根据你的需求修改projection数组中的列名,并根据你的数据模型进行处理。

如果你仍然遇到“无效列错误”,请检查你的列名拼写和大小写,并确保列名在表中存在。

相关内容

热门资讯

透视机巧!epoker底牌透视... 透视机巧!epoker底牌透视,cloudpoker怎么开挂(透视)都是存在有透视插件(哔哩哔哩)1...
透视练习!德普之星怎么设置埋牌... 透视练习!德普之星怎么设置埋牌,德普之星透视辅助软件(透视)确实有脚本方法(哔哩哔哩)1、让任何用户...
透视技法!wepoker怎么提... 透视技法!wepoker怎么提高运气,we poker辅助器下载(透视)竟然有脚本挂(哔哩哔哩)一、...
透视学习!hhpoker有没有... 透视学习!hhpoker有没有作必弊辅助,hh poker辅助器先试用(透视)竟然是有透视脚本(哔哩...
透视法子!德扑圈透视,德普之星... 透视法子!德扑圈透视,德普之星透视免费(透视)原来是真的透视工具(哔哩哔哩)1、德普之星透视免费公共...
透视经验!wepoker轻量版... 透视经验!wepoker轻量版透视方法,wepoker私人局规律(透视)一直是真的透视技巧(哔哩哔哩...
透视秘籍!wepoker免费辅... 透视秘籍!wepoker免费辅助器,wepoker怎么买辅助(透视)果然是真的脚本脚本(哔哩哔哩);...
透视学习!wepoker软件靠... 透视学习!wepoker软件靠谱么,wepoker透视有没有(透视)一直有透视脚本(哔哩哔哩)1、用...
透视绝活儿!德扑圈透视挂,德普... 透视绝活儿!德扑圈透视挂,德普之星私人局辅助免费(透视)竟然真的是有脚本工具(哔哩哔哩)1、德普之星...
透视教材!wepoker黑侠辅... 透视教材!wepoker黑侠辅助器,wepoker提高好牌率(透视)其实真的有透视神器(哔哩哔哩)1...