• MySQL去重中 distinct 和 group by 的区别


    今天在写业务需要对数据库重复字段进行去重时,因为是去重,首先想到的是distinct关键字。于是一小时过去了。。。。(菜鸟一个,大家轻点骂)

    我把问题的过程用sql语句演示给大家演示一下

    首先我使用的是mybatis-plus,代码如下

    1. QueryWrapper wrapper = new QueryWrapper<>();
    2. wrapper.select("DISTINCT project_id,company_id,company_name,is_delete").eq("project_id",projectId).eq("is_delete","0");

    即     "DISTINCT project_id,company_id,company_name,is_delete" 

    查出的结果

    id=null。这是我不希望看到的。没有id的话,下面的业务就不好走了。

    于是我在distinct后面加上了id,distinct查出来的数据就是全部数据了,相当于distinct没起作用。冥思苦想一小时。。。。

    后来想到了group by分组,于是用了一下

    1. LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>();
    2. wrapper.eq(ProjectCompany::getProjectId,projectId).eq(ProjectCompany::getIsDelete,"0").groupBy(ProjectCompany::getProjectId);
    LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>();
    wrapper.eq(ProjectCompany::getProjectId,projectId).eq(ProjectCompany::getIsDelete,"0").groupBy(ProjectCompany::getProjectId);
    

    发现查出来的数据也进行去重了,id也有值

    所以就很好奇 distinct和group by有啥区别,大概总结以下几点:

    distinct适合查单个字段去重,支持单列、多列的去重方式。 单列去重的方式简明易懂,即相同值只保留1个。 
    多列的去重则是根据指定的去重的列信息来进行,即只有所有指定的列信息都相同,才会被认为是重复的信息。

    而 group by 可以针对要查询的全部字段中的部分字段去重,它的作用主要是:获取数据表中以分组字段为依据的其他统计数据。

    如果觉得文章还不错,麻烦给小主点个赞支持一下!如果还有其他疑问,欢迎在留言区留言

  • 相关阅读:
    一文搞懂什么是 PostCSS
    基于HTML+CSS+JavaScript+Bootstarp响应式健身网站(web前端期末大作业)
    vmware虚拟机启动、使用ubuntu问题
    驶入脱贫“高速路”-国稻种芯-通榆县:稻谷农特产品推送进城
    Mac M1 jdk11 DNS错误
    零基础学Python:Matplotlib用法
    第一章 CIS 安全基准-kube-beach
    论文解读(XR-Transformer)Fast Multi-Resolution Transformer Fine-tuning for Extreme Multi-label Text Classification
    Git命令
    JavaScript——基础知识
  • 原文地址:https://blog.csdn.net/xiaoheihai666/article/details/127692013