android 数据库(sqlite)查询去除重复值
来源:互联网 发布:mysql 时间小于等于 编辑:程序博客网 时间:2024/04/30 13:04
转发请注明原文出处:http://blog.csdn.net/anyfive/article/details/45024263
在sqlite中,要去除重复值,只需要加上distinct关键字便可,如:select distinct * from XXX。当在android的sqlite中,必须有一列为_id,或查询的时候将某一列作为_id列,如select XX as _id from XXX。问题是,在select的时候,如果我们不查询_id,或者不在查询中将某一列作为_id;便会报错。例如,我们在gd表中存入广东省所有县名(counties)和其所在市名(cities),即此表中有三列,分别是:_id(主键),counties,cities;这时候,我们想提取出所有的市名,并将其装载入listview中,会发现当我们使用“select distinct cities from gd”时,编译器报错说没有_id;若是我们使用“select distinct _id,cities from gd”时,又无法去除重复值,因为_id是唯一的。这时候,我们可以用到一个函数:
Cursor query(boolean distinct, String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit,CancellationSignal cancellationSignal);
这个函数中,distinct即为是否去除重复值,table为要查询的数据表,columns为要查询的列;当我们传入的columns参数为new String[]{“cities”}时,会发现报错_id不存在,当我们传入的columns参数为new String[]{“_id”,”cities”}时,会发现并没有去除重复值。那么怎么办呢?我们继续看这个函数下面几个参数,我们注意到一个参数为groupBy:分组。我们试着传入“cities”,发现问题解决了,我们取出来的数据是去除重复之后的市,至此,问题解决。实例代码为:
Cursor cursor = db.getReadableDatabase().query(true, "gb", new String[]{"_id","cities"}, null, null, "cities", null, null, null, null);
至于这个函数其他参数,就留给读者自己去发掘吧。
- android 数据库(sqlite)查询去除重复值
- sqlite查询数据库去除重复记录
- 数据库查询去除重复值的方法
- android中的sqlite查询数据去掉重复值
- SQLite数据库 android 查询语句
- MySQL去除查询结果重复值
- MySQL去除查询结果重复值
- MySQL去除查询结果重复值
- MySQL去除查询结果重复值
- MySQLdistinct 去除查询重复值的结果
- Android 之 SQLite数据库 查询数据库
- Android 之 SQLite数据库 查询数据库
- sql查询去除重复键
- sql 查询去除重复记录
- sql查询去除重复项
- android中sqlite数据库查询优化方法
- Android SQLite数据库查询 cursor的使用
- android sqlite 查询数据库的总条数
- 非常简单的百度定位,只需要几个步骤即可
- USACO--3.1Stamps+DP
- 网络流复习
- DB2 CREATE TABEL
- netlink AF_NETLINK with CONFIG_NETLINK_MMAP
- android 数据库(sqlite)查询去除重复值
- 数据、常量、变量
- 网络流题集
- Web_PHP_DedeCMS_居中弹窗;
- mysqli语法
- 国内SEO人才与公司现状
- Samba 的使用与访问
- 当freemarker中EL表达式的值为空时出现异常的解决方法
- 文本文件生成时的一项注意点(UTF-8)