android 数据库(sqlite)查询去除重复值

本文讨论了在Android SQLite环境中如何通过SQL查询去除重复数据,并详细解释了一个解决特定问题的方法,即如何在不查询_id的情况下仍能去除重复项。通过使用Cursor.query函数并设置groupBy参数为需要去重的列名,可以实现这一目标。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


转发请注明原文出处:http://blog.youkuaiyun.com/anyfive/article/details/45024263


sqlite中,要去除重复值,只需要加上distinct关键字便可,如:select distinct * from XXX。当在androidsqlite中,必须有一列为_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);

至于这个函数其他参数,就留给读者自己去发掘吧。




评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值