首页
学习
活动
专区
圈层
工具
发布

MySQL中distinct和group by去重的区别

MySQL中distinct和group by去重的区别 在MySQL中,我们经常需要对查询结果进行去重,而DISTINCT和GROUP BY是实现这一功能的两种常见方法。...而使用GROUP BY可以查询一个或多个字段。 使用业务场景不同 统计去重之后的总数量需要使用DISTINCT,而统计分组明细或在分组明细的基础上添加查询条件时,就得使用GROUP BY。...性能不同 如果去重的字段有索引,那么GROUP BY和DISTINCT都可以使用索引,此情况下它们的性能是相同的。...而当去重的字段没有索引时,DISTINCT的性能可能会高于GROUP BY,因为在MySQL 8.0之前,GROUP BY有一个隐藏的功能会进行默认的排序,这样就会触发filesort从而导致查询性能降低...总结 大部分场景下DISTINCT是特殊的GROUP BY,但二者也有细微的区别,比如它们在查询结果集上、使用的具体业务场景上,以及性能上都是不同的。

24800
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL中的GROUP BY和DISTINCT:去重的效果与用法解析

    在MySQL数据库中,经常会遇到需要对数据进行分组和去重的情况。为了达到这个目的,我们通常会使用GROUP BY和DISTINCT这两个关键字。虽然它们都可以用于去重,但是它们具有不同的用法和效果。...本文将详细解析MySQL中的GROUP BY和DISTINCT的用法,并比较它们对同一字段的去重效果是否相同。...它不会去除重复的行,而是将重复的行分组,并对每个组应用聚合函数。因此,如果我们在上述示例中的查询中不使用COUNT(*)函数,而是使用其他聚合函数如SUM()、AVG()等,将会得到不同的结果。...二、DISTINCT的用法及效果DISTINCT关键字用于返回唯一不重复的行。当我们希望从一个表格中获取某一列的所有不重复的值时,可以使用DISTINCT关键字。...结论通过本文的介绍,我们了解了Mysql中的Group和Distinct的用法,并对它们进行了比较和对比。Group By关键字用于将结果集按照指定的字段进行分组,适用于分组计算和聚合操作。

    8.9K50

    MySQL函数-concat、concat_ws、group_concat

    Mysql 函数concat、concat_ws和group_concat 本文介绍的是MySQL中3个函数的使用,主要是针对字符串的连接合并处理: concat concat_ws group_concat...说明具体使用,以下面这个表中的第一条记录为例: ?...NULL值):连接的时候跳过NULL值 concat_ws不会忽略空字符串;concat会忽略空字符串 下面通过几个例子来说明使用方法: -- 1、指定不同的连接符号:分别指定逗号和加号 mysql>...合起来就是分组连接,具体语法为: GROUP_CONCAT(DISTINCT expression ORDER BY expression SEPARATOR sep); DISTINCT子句用于在连接分组之前消除组中的重复值...s_score表示对分数去重,取出每个学生的不同分数(表中每个学生的分数都不相同,结果同上) mysql> select s_id, group_concat(distinct s_score order

    2.8K10

    Mysql 函数concat、concat_ws和group_concat

    Mysql 函数concat、concat_ws和group_concat 本文介绍的是MySQL中3个函数的使用,主要是针对字符串的连接合并处理: concat concat_ws group_concat...) 3个例子说明具体使用,以下面这个表中的第一条记录为例: [008eGmZEgy1gmvmc46zvhj30lw0hwn3h.jpg] -- 1、字符之间不加连接符 mysql> select concat...如果分隔符是NULL,结果为NULL 函数后忽略任何分割符参数后的NULL值(分隔符之后的NULL值):连接的时候跳过NULL值 concat_ws不会忽略空字符串;concat会忽略空字符串 下面通过几个例子来说明使用方法...合起来就是分组连接,具体语法为: GROUP_CONCAT(DISTINCT expression ORDER BY expression SEPARATOR sep); DISTINCT子句用于在连接分组之前消除组中的重复值...s_score表示对分数去重,取出每个学生的不同分数(表中每个学生的分数都不相同,结果同上) mysql> select s_id, group_concat(distinct s_score order

    9K10

    concat效率 mysql_Mysql常用函数之Concat函数

    MySQL中concat函数 使用方法: CONCAT(str1,str2,…) 返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。...MySQL的concat函数可以连接一个或者多个字符串,如 mysql> select concat(’10’); +————–+ | concat(’10’) | +————–+ | 10 | +——...+————————+ 1 row in set (0.00 sec) 2.MySQL中concat_ws函数 使用方法: CONCAT_WS(separator,str1,str2,…) CONCAT_WS...如连接后以逗号分隔 mysql> select concat_ws(‘,’,’11’,’22’,’33’); +——————————-+ | concat_ws(‘,’,’11’,’22’,’33’)...| +——————————-+ | 11,22,33 | +——————————-+ 1 row in set (0.00 sec) 和MySQL中concat函数不同的是, concat_ws函数在执行的时候

    1.8K40

    如何在 Kubernetes 环境中搭建 MySQL(三):使用 PVC 挂接 RBD

    MySQL in Kubernetes MySQL 中的数据是关键信息,是有状态的,不可能随着 MySQL pod 的销毁而被销毁,所以数据必须要外接到一个可靠的存储系统中,目前已经有了 Ceph 系统...使用 keyring 文件连接 RBD 首先让我们用最基础的方式连接 Ceph,以下就是 yaml 文件,简要介绍一下关键字段: monitors: 连接的 Ceph monitor 地址,注意要更改成环境中对应的...imageformat:建议使用 2,1 是更老的格式。...pool:Ceph 中的 pool。 image:Ceph RBD 创建的镜像名称。...k8s 环境里,不过这还是很初级的方案,毕竟在挂载之前还需要手动在 RBD 中创建镜像,太不 cloud native 了,接下来的文章将演示如何动态的使用 RBD 镜像。

    1.2K30

    如何在 Kubernetes 环境中搭建 MySQL(四):使用 StorageClass 挂接 RBD

    简介 在系列文章的第三篇中,讲到了如何使用 PV 和 PVC 挂载 RBD 上建立好的块存储镜像,但这还是不足以满足 cloud native 环境下的需求,试想如果部署一个应用,需要申请十个 RBD...,注意要改成 ceph.com/rbd,kubernetes.io/rbd 是无法正常使用的,原因是 kubernetes.io/rbd 会在 kube-controller-manager 镜像中查找...adminId | userId:连接 ceph 的权限,admin 已存在,如果有需要创建其他用户,可以在 Ceph 集群中创建,并赋予对应的权限,简单使用的话,admin 也足够了。...external-storage 中提供的方式是部署在 default namespace 中的,如果要部署在其他 namespace 中,需要做对应的修改。...claimName: mysql-dynamic-pvc 至此完成 RBD 的动态挂载,下一篇文章来谈一谈如何使用 StatefulSet 部署主从同步的 MySQL 集群。

    1.3K20
    领券