sql distinct 多列问题

本文探讨了SQL中使用DISTINCT关键字进行去重查询的方法,并对比了单列与多列查询的区别。此外,还介绍了如何利用GROUP BY和子查询来提高查询效率。

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

 查询单列,使用select distinct name from photos;是没有问题的。

但若想查询多列,如select distinct name,nickname,department from photos;是将三列完全相同的内容过滤掉,但凡三列有一列不同,均会列出来。
若将distinct放后面,如select nickname,department,distinct name from photos;报错,distinct必须放在开头。将distinct放到where里,也是报错。
可以使用select *, count(distinct name) from photos group by name;最后一项是多余的,不用管就行了,目的可以达到其中,group by 必须放在 order by 和 limit之前,不然会报错。

或者可以使用select * from photos where id in (select max(id) from photos group by name),但是执行效率很低,能明显感觉出数据库的处理时间。 如果数据可以保证--随着id递增,数据越新,则使用此语句可查询出最新结果。上面的语句则不保证。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值