Android ContentResolver如何查询数据

661
2024/9/3 12:31:42
栏目: 编程语言
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

在Android中,ContentResolver是一个用于与其他应用程序共享数据的接口

  1. 获取ContentResolver实例:
ContentResolver contentResolver = getContentResolver();
  1. 确定要查询的URI。URI通常指向一个内容提供者,它是一个包含您要查询的数据的应用程序。例如,要查询联系人数据,可以使用ContactsContract.Contacts.CONTENT_URI。

  2. 确定要查询的列。这是一个字符串数组,表示您想从内容提供者中检索的列名称。例如,要查询联系人的姓名和电话号码,可以使用以下列:

String[] projection = new String[]{
    ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME,
    ContactsContract.CommonDataKinds.Phone.NUMBER
};
  1. (可选)指定查询条件。这是一个WHERE子句,用于过滤结果集。例如,要查询姓氏为"Smith"的联系人,可以使用以下条件:
String selection = ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME + " LIKE ?";
String[] selectionArgs = new String[]{"%Smith%"};
  1. (可选)指定排序顺序。这是一个ORDER BY子句,用于对结果集进行排序。例如,要按姓名排序,可以使用以下排序顺序:
String sortOrder = ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME + " ASC";
  1. 使用ContentResolver的query()方法执行查询:
Cursor cursor = contentResolver.query(
    ContactsContract.CommonDataKinds.Phone.CONTENT_URI, // URI
    projection,                                         // 要查询的列
    selection,                                          // WHERE子句
    selectionArgs,                                       // WHERE子句的参数
    sortOrder                                            // ORDER BY子句
);
  1. 处理查询结果。使用Cursor对象遍历结果集并处理数据。例如,打印每个联系人的姓名和电话号码:
if (cursor != null) {
    while (cursor.moveToNext()) {
        String displayName = cursor.getString(
            cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME));
        String phoneNumber = cursor.getString(
            cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));
        Log.d("Contact", displayName + ": " + phoneNumber);
    }
    cursor.close();
}

这就是如何使用Android的ContentResolver查询数据。请注意,查询不同的内容提供者可能需要不同的URI、列和查询条件。始终参考相应的文档以了解如何正确地查询特定的内容提供者。

辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: Android中CompoundButton的作用是什么