• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL中使用去重distinct方法的示例详解

    一 distinct

    含义:distinct用来查询不重复记录的条数,即distinct来返回不重复字段的条数(count(distinct id)),其原因是distinct只能返回他的目标字段,而无法返回其他字段

    用法注意:

    1.distinct【查询字段】,必须放在要查询字段的开头,即放在第一个参数;
    2.只能在SELECT 语句中使用,不能在 INSERT, DELETE, UPDATE 中使用;
    3.DISTINCT 表示对后面的所有参数的拼接取 不重复的记录,即查出的参数拼接每行记录都是唯一的
    4.不能与all同时使用,默认情况下,查询时返回的就是所有的结果。

    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 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • MySQL去重该使用distinct还是group by?
    • Mysql中distinct与group by的去重方面的区别
    上一篇:mysql-connector-java.jar包的下载过程详解
    下一篇:Mysql按条件计数多种实现方法详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MySQL中使用去重distinct方法的示例详解 MySQL,中使,用去,重,distinct,