`
king_tt
  • 浏览: 2100289 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

【Android 开发教程】条件查询、过滤和排序

 
阅读更多

本章节翻译自《Beginning-Android-4-Application-Development》,如有翻译不当的地方,敬请指出。

原书购买地址http://www.amazon.com/Beginning-Android-4-Application-Development/dp/1118199545/


Projections

managedQuery()的第二个参数(CursorLoader类的第三个参数)控制查询返回列的数量。之前的代码,传入的是null,就是把所有的列都取到。

       Cursor c;
        if (android.os.Build.VERSION.SDK_INT < 11) {
            c = managedQuery(allContacts, null, null, null, null);
        } else {
            CursorLoader cursorLoader = new CursorLoader(this, allContacts,
                    null, null, null, null);
            c = cursorLoader.loadInBackground();
        }
可以创建一个数组,指定要查询哪些列。

        Uri allContacts = ContactsContract.Contacts.CONTENT_URI;

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

        Cursor c;
        if (android.os.Build.VERSION.SDK_INT < 11) {
            c = managedQuery(allContacts, projection, null, null, null);
        } else {
            CursorLoader cursorLoader = new CursorLoader(this, allContacts,
                    projection, null, null, null);
            c = cursorLoader.loadInBackground();
        }

这样,就指定的需要查询的列:名字和是否有手机号。

Filtering

managedQuery()方法的第3和第4个参数(CursorLoader类的第4和第5个参数)。这两个参数指定了SQL语句中的WHERE条件,进行条件查询。

举个例子,下面的代码返回名字以"三"为结尾的联系人。

        Uri allContacts = ContactsContract.Contacts.CONTENT_URI;

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

        Cursor c;
        if (android.os.Build.VERSION.SDK_INT < 11) {
            c = managedQuery(allContacts, projection,
                    ContactsContract.Contacts.DISPLAY_NAME + " LIKE ?",
                    new String[] { "%三" }, null);
        } else {
            CursorLoader cursorLoader = new CursorLoader(this, allContacts,
                    projection, ContactsContract.Contacts.DISPLAY_NAME
                            + " LIKE ?", new String[] { "%三" }, null);
            c = cursorLoader.loadInBackground();
        }
经查询,会返回“张三”。

Sorting

managedQuery()和CursorLoader的最后一个参数。这个参数指定了SQL语句的ORDER BY条件,进行结果排序。

下面的代码对联系人进行名字的升序排列。

        Uri allContacts = ContactsContract.Contacts.CONTENT_URI;

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

        Cursor c;
        if (android.os.Build.VERSION.SDK_INT < 11) {
            c = managedQuery(allContacts, projection,
                    ContactsContract.Contacts.DISPLAY_NAME + " LIKE ?",
                    new String[] { "%三" },
                    ContactsContract.Contacts.DISPLAY_NAME + " ASC");

        } else {
            CursorLoader cursorLoader = new CursorLoader(this, allContacts,
                    projection, ContactsContract.Contacts.DISPLAY_NAME
                            + " LIKE ?", new String[] { "%三" },
                    ContactsContract.Contacts.DISPLAY_NAME + " ASC");
            c = cursorLoader.loadInBackground();
        }


分享到:
评论

相关推荐

    Android开发教程(完整版)

    新版Android开发教程&笔记--基础入门一.pdf 新版Android开发教程&笔记--基础入门二.pdf 新版Android开发教程&笔记三--环境搭建与解析.pdf 新版Android开发教程&笔记四--Dalvik ADB.pdf 新版Android开发教程+笔记五--...

    新版Android开发教程及笔记-完整版.pdf

    新版Android开发教程&笔记--基础入门一.pdf 新版Android开发教程&笔记--基础入门二.pdf 新版Android开发教程&笔记三--环境搭建与解析.pdf 新版Android开发教程&笔记四--Dalvik ADB.pdf 新版Android开发教程+笔记五--...

    Android开发教程笔记完全版 pdf

    Android开发教程笔记完全版 pdf.我看了一下,自己感觉可以.

    Android开发教程+笔记 Android开发教程+笔记

    Android开发教程+笔记 Android开发教程+笔记 Android开发教程+笔记 Android开发教程+笔记 Android开发教程+笔记 Android开发教程+笔记 Android开发教程+笔记 Android开发教程+笔记 Android开发教程+笔记 Android开发...

    [14本经典Android开发教程]-3-Android SDK 中文开发文档

    [14本经典Android开发教程]-3-Android SDK 中文开发文档 什么是 Android? Android 是一个专门针对移动设备的软件集,它包括一个操作系统,中间件和一些重要的应用程序。Beta版的 Android SDK 提供了在Android 平台上...

    新版Android开发教程.rar

    的 Android SDK 提供了在 Android 平台上使用 JaVa 语言进行 Android 应用开发必须的工具和 API 接口。 特性 • 应用程序框架 支持组件的重用与替换 • Dalvik Dalvik Dalvik Dalvik 虚拟机 专为移动设备优化 • ...

    android基础教程

    新版Android开发教程&笔记1--基础入门一.pdf 新版Android开发教程&笔记2--基础入门二.pdf 新版Android开发教程&笔记3--环境搭建与解析.pdf 新版Android开发教程&笔记4--Dalvik ADB.pdf 新版Android开发教程+笔记5--...

    [14本经典Android开发教程]-9-Android2.3用户手册

    [14本经典Android开发教程] 9 Android2 3用户手册 已上传8本: [14本经典Android开发教程] 1 Android开发从入门到精通 http: download csdn net detail cleopard 8355245 [14本经典Android开发教程] 2 Android...

    Android开发案例驱动教程 配套代码

    《Android开发案例驱动教程》 配套代码。 注: 由于第12,13,14章代码太大,无法上传到一个包中。 这三节代码会放到其他压缩包中。 作者:关东升,赵志荣 Java或C++程序员转变成为Android程序员 采用案例驱动模式...

    Android NFC 开发教程

    Android NFC 开发教程 NFC手机推出后,基于NFC的Android开发升温,银行卡、公交卡充值、余额查询等业务不断推出,开发NFC功能的Android程序也成为程序猿们的工作。

    [14本经典Android开发教程]-11-Android系统移植技术详解

    [14本经典Android开发教程]-11-Android系统移植技术详解 -------------------------------------------------- (1)安装如下软件包 sudo apt-get install git-core sudo apt-get install gnupg sudo apt-get install...

    [14本经典Android开发教程]-4-Android应用程序开发36技

    [14本经典Android开发教程]-4-Android应用程序开发36技 本书共分为4篇: ※ 第一篇:介绍应用框架概念、原理和特性。 ※ 第二篇:阐述应用框架之设计技巧。亦即,如何打造应用框架。 (注:如果你的职务是「使用」...

    老罗android开发视频教程全集百度网盘下载

    【第一版第九章】老罗Android开发视频--存储数据和文件(7集) 【第一版第十章】老罗Android开发视频--对话框介绍(4集) 【第一版第十一章】老罗Android开发视频--通知的使用(2集) 【第一版第十二章】老罗...

    14本安卓android开发教程书籍源代码.rar

    14本安卓android开发教程书籍源代码让您从安卓开发新手到高手,快速具备独立开发经验,最全api教程大合集 安卓AndroidAPI教程 安卓android编译总结 安卓android开发从零开始代码若水 二维码生成图片 安卓中国象棋源码 ...

    [14本经典Android开发教程]-8-Linux内核阅读心得体会

    [14本经典Android开发教程] 8 Linux内核阅读心得体会 读核感悟 2 读核感悟 Linux内核启动 内核的生成 2 读核感悟 Linux内核启动 从hello world说起 3 读核感悟 Linux内核启动 BIOS 5 读核感悟 Linux内核启动 setup...

    14本经典android开发教程

    Android开发从入门到精通.doc Android 开发环境搭建步骤详细图解.pdf Android编程入门教程.pdf linux Android基础知识总结.pdf Android新手开发教程.pdf .....

    [14本经典Android开发教程]-7-Android编程入门教程

    [14本经典Android开发教程]-7-Android编程入门教程 -------------------------------------------------- 本文为以前已经使用Java编程并想开始为Android平台开发的开发者编写。我试着尽可能地多的"展开",在合适的每...

    [14本经典Android开发教程]-2-Android开发手册—API函数详解

    [14本经典Android开发教程] 2 Android开发手册 API函数详解 一 TextView的API 1 1 结构 java lang Object android view View android widget TextView 直接子类: Button CheckedTextView Chronometer DigitalClock...

    Android开发基础教程整理版【PDF】

    Android开发基础教程整理版【PDF】 Android开发教程,基础版,由一系列的教程整理而得,相对基础的知识,高手们就不要看了,本书主要对象是即将跨入Android的编程行列或已经跨入但仍一头雾水的朋友们。在智能手机...

    Android 仿联系人列表 实现ListView的A-Z字母排序和过滤搜索功能

    实现ListView的A-Z字母排序和过滤搜索功能,是一个功能完整的demo

Global site tag (gtag.js) - Google Analytics