在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
一 distinct 含义:distinct用来查询不重复记录的条数,即distinct来返回不重复字段的条数(count(distinct id)),其原因是distinct只能返回他的目标字段,而无法返回其他字段 用法注意: 1.distinct【查询字段】,必须放在要查询字段的开头,即放在第一个参数; 1.1只对一个字段查重 对一个字段查重,表示选取该字段一列不重复的数据。 示例表:psur_list PLAN_NUMBER字段去重,语句: SELECT DISTINCT PLAN_NUMBER FROM psur_list; 结果如下: 1.2多个字段去重 对多个字段去重,表示选取多个字段拼接的一条记录,不重复的所有记录 示例表:psur_list PLAN_NUMBER和PRODUCT_NAME字段去重,语句: SELECT DISTINCT PLAN_NUMBER,PRODUCT_NAME FROM psur_list; 结果如下: 期望结果:只对第一个参数PLAN_NUMBER取唯一值 解决办法一:使用group_concat 函数 语句: SELECT GROUP_CONCAT(DISTINCT PLAN_NUMBER) AS PLAN_NUMBER,PRODUCT_NAMEFROM psur_list GROUP BY PLAN_NUMBER 解决办法二:使用group by 语句: SELECT PLAN_NUMBER,PRODUCT_NAME FROM psur_list GROUP BY PLAN_NUMBER 结果如下: 1.3针对null处理 distinct不会过滤掉null值,返回结果包含null值 表psur_list如下: 对COUNTRY字段去重,语句: SELECT DISTINCT COUNTRY FROM psur_list 结果如下: 1.4与distinctrow同义 语句: SELECT DISTINCTROW COUNTRY FROM psur_list 结果如下: 二 聚合函数中使用distinct 在聚合函数中DISTINCT 一般跟 COUNT 结合使用。count()会过滤掉null项 语句: SELECT COUNT(DISTINCT COUNTRY) FROM psur_list 结果如下:【实际包含null项有4个记录,执行语句后过滤null项,计算为3】 到此这篇关于MySQL中使用去重distinct方法的示例详解的文章就介绍到这了,更多相关MySQL 去重distinct 内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论