【Android 开发教程】条件查询、过滤和排序
2013-08-06 15:15
489 查看
本章节翻译自《Beginning-Android-4-Application-Development》,如有翻译不当的地方,敬请指出。
原书购买地址http://www.amazon.com/Beginning-Android-4-Application-Development/dp/1118199545/
Projections
managedQuery()的第二个参数(CursorLoader类的第三个参数)控制查询返回列的数量。之前的代码,传入的是null,就是把所有的列都取到。
这样,就指定的需要查询的列:名字和是否有手机号。
Filtering
managedQuery()方法的第3和第4个参数(CursorLoader类的第4和第5个参数)。这两个参数指定了SQL语句中的WHERE条件,进行条件查询。
举个例子,下面的代码返回名字以"三"为结尾的联系人。
Sorting
managedQuery()和CursorLoader的最后一个参数。这个参数指定了SQL语句的ORDER BY条件,进行结果排序。
下面的代码对联系人进行名字的升序排列。
原书购买地址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 开发教程】经过预定义的查询字符串常量
- ormlite 在android中 排序 条件查询
- solr查询索引,各种查询,查询字符串,过滤查询,条件查询,排序查询、分页查询、高亮查询
- Android项目实战视频教程_快递轨迹查询应用开发
- sqlserver中分组查询,条件过滤,排序,写这个sql,我为自己感到骄傲
- springmvc4+spring4+hibernate4注解开发,分页查询,表头排序,多条件模糊查询,查询自动补全功能
- Android 编程之入门开发文件夹管理器开发文件的过滤与排序-3
- 隔行变色,选中变色,鼠标变小手样式;姓名查询条件 过滤敏感字符 下拉列表排序 非空验证添加信息 点击按钮删除
- 仿Android联系人SideBar排序,根据拼音A-Z字母快速导航联系人姓名,以及输入搜索条件过滤,显示姓名的文字图片,添加挤压动画
- 07--MySQL自学教程:DQL(Data Query Language:数据库查询语言)简介、基础查询、条件查询、模糊查询以及排序(一)
- mongodb 3.x 客户端开发四:golang根据条件过滤查询mongodb集合数据
- ormlite 在android中 排序 条件查询
- apklug插件托管服务开发教程之按条件查询云端插件-01
- Vaadin Web应用开发教程(47): SQLContainer-过滤及排序
- 07--MySQL自学教程:DQL(Data Query Language:数据库查询语言)简介、基础查询、条件查询、模糊查询以及排序(一)
- Android开发学习笔记:SQLite数据库查询数据时中文数据按字母顺序排序
- 仿Android联系人SideBar排序,根据拼音A-Z字母快速导航联系人姓名,以及输入搜索条件过滤,显示姓名的文字图片
- ormlite 在android中 排序 条件查询
- Android项目实战视频教程_快递轨迹查询应用开发