MySQL对某一字段去重

mysql有一个去重关键字distinct,但是如果查询的字段有很多,而想要去重的字段只是其中的某一个,那么仅仅用distinct是完成不了的,distince只能做到你查询的那些字段都是重复时才会去重。
比如有一张用户表的数据是这样的:
在这里插入图片描述
这里我们本意是想查出一条数据,如果是这样写SQL语句:

SELECT DISTINCT USER_NAME FROM u_user

这样查出来的数据的确只有一条。可是如果我们是这样写:

SELECT DISTINCT USER_NAME,USER_SEX FROM u_user

那么出来的还是两条数据,因为这个去重是指 USER_NAME 和 USER_SEX 同时重复时才会去重。
注意distinct只能放在字段的最前面,所以如果这么写是会报错的:

SELECT USER_SEX, DISTINCT USER_NAME FROM u_user

这种写法MySQL不支持,会报错。这里可以用distinct和group by相结合的方式去完成:

SELECT USER_NAME, USER_SEX,COUNT(DISTINCT USER_NAME) FROM u_user GROUP BY USER_NAME

这样结果就只有一条数据了。

  • 6
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值