位置: 编程技术 - 正文

MySQL中distinct与group by语句的一些比较及用法讲解

编辑:rootadmin

推荐整理分享MySQL中distinct与group by语句的一些比较及用法讲解,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

在数据表中记录了用户验证时使用的书目,现在想取出所有书目,用DISTINCT和group by都取到了我想要的结果,但我发现返回结果排列不同,distinct会按数据存放顺序一条条显示,而group by会做个排序(一般是ASC)。 DISTINCT 实际上和 GROUP BY 操作的实现非常相似,只不过是在 GROUP BY 之后的每组中只取出一条记录而已。所以,DISTINCT 的实现和 GROUP BY 的实现也基本差不多,没有太大的区别,同样可以通过松散索引扫描或者是紧凑索引扫描来实现。 那DISTINCT 和GROUP BY哪个效率更高? DISTINCT操作只需要找出所有不同的值就可以了。而GROUP BY操作还要为其他聚集函数进行准备工作。从这一点上将,GROUP BY操作做的工作应该比DISTINCT所做的工作要多一些。 但实际上,GROUP BY 效率会更高点,为什么呢?对于DISTINCT操作,它会读取了所有记录,而GROUP BY需要读取的记录数量与分组的组数量一样多,也就是说比实际存在的记录数目要少很多。

下面来看MySQL中distinct及group by的一些用法分享。

1.测试一

用distinct过滤掉两列都相同的记录

返回

2.测试二将表student的数据改为如下:

返回如下,说明distinct后面有多于一列的字段时,只有每列的值完全相同才过滤

3.测试三

group by按两列同时分组

group by按两列同时分组,同时在后面加上having的条件

MySQL中distinct与group by语句的一些比较及用法讲解

返回c 2

4.测试四关于group by后面limit的测试

经过以上两个测试可以看出,如果sql语句中含有limit,limit是对用group by进行分组,并进行相关计算以后的limit操作,而不是对limit后面的指定记录数进行分组,从n那一列的数据每一行的值都大于就可以看出来。

5.测试五用以下的两种形式的distinct均可以得到相同的记录数,写法不一样,结果是一样的。

6.测试六field singername is string,max(singername),如果singername有些列为空,有些列不为空,则max(singername)取非空的值,如果一列为zxx,一列为lady,则取zxx,按字母顺利取的。

7.Sql语句中where,group by,order by及limit的顺序

8.关于group by与count的问题如果sql语句中含有group by,则最好不要将count sql转换为select count(*) from xxx,否则select与from之间的字段很有可能是后面要使用的,例如

mysql 数据库死锁原因及解决办法 死锁(Deadlock)所谓死锁:是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去

mysql数据库锁的产生原因及解决办法 数据库和操作系统一样,是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对

批量 kill mysql 中运行时间长的sql KILL语法KILL[CONNECTION|QUERY]thread_id每个与mysqld的连接都在一个独立的线程里运行,您可以使用SHOWPROCESSLIST语句查看哪些线程正在运行,并使用KILLthread_id语

标签: MySQL中distinct与group by语句的一些比较及用法讲解

本文链接地址:https://www.jiuchutong.com/biancheng/319726.html 转载请保留说明!

上一篇:MySQL中distinct语句的基本原理及其与group by的比较

下一篇:mysql 数据库死锁原因及解决办法(mysql 死锁处理)

  • 建筑行业有哪种职业
  • 一年房租正常摊销多少
  • 材料出入库制度
  • 坏账准备计提比率计算公式
  • 社保费公司部分怎么算
  • 房产税从价计征扣除比例
  • 一般纳税人企业所得税多久申报一次
  • 建筑企业施工管理人员
  • 差额开票如何入账
  • 行政单位明细账包括哪些
  • 增值税缴纳的罚款怎么算
  • 应付账款以前年度挂错
  • 未实缴出资的股东退股
  • 加计扣除所得税怎么算
  • 跨年收到暂估费用的发票如何处理
  • 给客户赔偿如何入账
  • 汽车销售公司购进车辆怎么做账
  • 关于转让费的问题
  • 企业股权设计咨询这个行业怎么样
  • 一般纳税人销售旧货
  • 建筑企业法定代表人和建筑公司资质不是一个人
  • 住房公积金利息怎么算的
  • 补提以前年度费用在年度报表中怎么填
  • 1697509422
  • 多提费用没计入以前年度损益调整,汇算时怎么处理
  • mac如何重装系统win10
  • 单位社保部分会扣吗
  • 王者荣耀怎么快速获得金币
  • 公司分期付款购车账务处理
  • 个人所得税租房和房贷只能二选一吗
  • ubuntu22.04更换RTX 4090显卡后,安装驱动和pytorch记录
  • php开发常用技术
  • PHP+Mysql+jQuery中国地图区域数据统计实例讲解
  • phpadmin官网
  • 怎么扣除税费
  • linux 命令行
  • 缴纳租房押金会被骗吗
  • echarts css
  • 企业会计准则应付利息计入什么科目?
  • 进项税大于销项税,不用缴纳增值税
  • 工程分包合同
  • netbeans for php
  • 中标费用入什么科目
  • 产权转移数据印花税计税依据含不含增值税
  • 100万的工程怎么开发票
  • SQL Server 跨库同步数据
  • 珠宝首饰可以开发票吗
  • 预付房租如何做分录
  • 出口货物退运已补税(未退税)证明
  • 固定资产贷款利息计算器
  • 捐赠人赞助属于什么会计科目
  • 用友反结账怎么操作
  • 企业用实物资产出资 增值税
  • 网上报税流程演示2019
  • 游戏公司的主营业务成本
  • 预付货款属不属于消费信用
  • 10万以下销售额怎么算
  • 企业预交所得税税率
  • 研发投入算到产值里吗
  • sqlserver界面
  • xp 指定的域不存在,或无法联系
  • ubuntu怎样
  • 苹果15手机价格和图片颜色
  • safari 快捷键
  • linux如何修改文件创建时间
  • windows xp怎样禁止弹出广告
  • 电脑联想windows7
  • skynetave.exe - skynetave是什么进程 有什么用
  • win8系统触摸板按键不能用
  • 事件处理的三个要素
  • android framework.jar
  • android开发手册
  • 删除cmd命令记录
  • python基础入门教程
  • jquery foreach循环
  • 银行赠送礼品活动方案
  • 怎样查询灵活就业养老保险缴费记录
  • 怎么看有没有欠税
  • 发货确认收入还是以开票确认收入
  • 园区地税局在哪里
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设