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

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章