位置: 编程技术 - 正文

MySQL中无GROUP BY情况下直接使用HAVING语句的问题探究(mysql中的groupby)

编辑:rootadmin

推荐整理分享MySQL中无GROUP BY情况下直接使用HAVING语句的问题探究(mysql中的groupby),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql中无符号,mysql中无法输入汉字,mysql中无符号整数类型需要使用什么关键字修饰,mysql group by sum,mysql中无法输入汉字,mysql中无法输入汉字,mysql中无法输入汉字,mysql中无符号整数类型需要使用什么关键字修饰,内容如对您有帮助,希望把文章链接给更多的朋友!

今天有同学给我反应,有一张表,id是主键,这样的写法可以返回一条记录:

但是只是把MIN换成MAX,这样返回就是空了:

这是为什么呢?

我们先来做个试验,验证这种情况。

这是表结构,初始化两条记录,然后试验:

初看之下,好像真的是这样哎,怎么会这样呢?

我再试一下,把a字段改一个为,然后试下a字段:

我擦,这回MAX能返回,MIN不能了,这又是为啥呢?

旁白

一般来说,HAVING子句是配合GROUP BY使用的,单独使用HAVING本身是不符合规范的,

MySQL中无GROUP BY情况下直接使用HAVING语句的问题探究(mysql中的groupby)

但是MySQL会做一个重写,加上一个GROUP BY NULL,”SELECT * FROM t HAVING id=MIN(id)”会被重写为”SELECT * FROM t GROUP BY NULL HAVING id=MIN(id)”,这样语法就符合规范了。

继续……

但是,这个 GROUP BY NULL 会产生什么结果呢?经过查看代码和试验,可以证明,GROUP BY NULL 等价于 LIMIT 1:

也就是说,GROUP BY NULL 以后,只会有一个分组,里面就是第一行数据。

但是如果这样,MIN、MAX结果应该是一致的,那也不应该MAX和MIN一个有结果,一个没结果啊,这是为什么呢,再做一个测试。

修改一下数据,然后直接查看MIN/MAX的值:

是不是发现问题了?

MAX/MIN函数取值是全局的,而不是LIMIT 1这个分组内的。

因此,当GROUP BY NULL的时候,MAX/MIN函数是取所有数据里的最大和最小值!

所以啊,”SELECT * FROM t HAVING id=MIN(id)”本质上是”SELECT * FROM t HAVING id=1″, 就能返回一条记录,而”SELECT * FROM t HAVING id=MAX(id)”本质上是”SELECT * FROM t HAVING id=3″,当然没有返回记录,这就是问题的根源。

测试一下GROUP BY a,这样就对了,每个分组内只有一行,所以MAX/MIN一样大,这回是取得组内最大和最小值。

GROUP BY NULL时MAX/MIN的行为,是这个问题的本质,所以啊,尽量使用标准语法,玩花样SQL之前,一定要搞清楚它的行为是否与理解的一致。

MySQL中删除重复数据的简单方法 MYSQL里有五百万数据,但大多是重复的,真实的就万,于是想怎样把这些重复的数据搞出来,在网上找了一圈,好多是用NOTIN这样的代码,这样效率很

在MySQL中实现二分查找的详细教程 给定一个升序排列的自然数数组,数组中包含重复数字,例如:[1,2,2,3,4,4,4,5,6,7,7]。问题:给定任意自然数,对数组进行二分查找,返回数组正确的位置

在MySQL中使用STRAIGHT_JOIN的教程 问题通过「SHOWFULLPROCESSLIST」语句很容易就能查到问题SQL,如下:SELECTpost.*FROMpostINNERJOINpost_tagONpost.id=post_tag.post_idWHEREpost.status=1ANDpost_tag.tag_id=ORDERBYpost.

标签: mysql中的groupby

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

上一篇:探究MySQL中varchar的定义长度(mysql varchar2)

下一篇:MySQL中删除重复数据的简单方法(mysql删除重复的id但各保留一个)

  • 中国注册税务师协会法律法规库
  • 出售可供出售金融资产的利得属于什么活动
  • 先付款后签合同 法律效力
  • 工会经费计入成本费用
  • 公章未备案是否不合法
  • 建筑工程免税项目
  • 应收账款属于非流动资产吗
  • 分类账和明细账平行登记规则
  • 采购折扣怎么结转成本?
  • 净利润提盈余公积
  • 发票专用章管理办法
  • 购买债券投资的交易费用
  • 上期认证的发票本期能抵扣吗
  • 安装服务需要预缴税款吗
  • 厦门新车购置税计算
  • steam打开速度
  • 王者荣耀如何充值退款
  • 独立账户负债核算内容
  • 私营企业员工享受探亲假吗
  • 缴纳印花税和残值的比例
  • php与jquery
  • win10升级win11报错
  • 权益法核算的长期股权投资入账价值
  • 不征税收入用于支出所形成的费用是什么意思
  • win10开机强制进入修复模式
  • 长期挂账的其他应付款转营业外收入情况说明
  • 虚开发票的管理办法是什么?
  • 固定资产置换存货的账务处理
  • 魅族路由器mini刷机
  • 关于我的家乡作文1000字
  • 无法偿还的应付账款计入什么科目
  • 月收入10万以下免增值税
  • css过渡动画属性
  • elementui怎么样
  • javascript中文手册
  • nodejs安装及环境配置vue
  • 社会保险费的征收机构由什么规定
  • python安装后找不到了
  • 6.824 Lab 1: A simple web proxy
  • 外管证注销后发票还可以重开吗?
  • phpcms不支持缩略图和水印怎么办
  • 不开增值税发票的销售收入报税的操作流程是?
  • sql分页语句
  • 增值税附加税印花税都是什么
  • 购买固定资产的增值税计入成本吗
  • 补充养老保险和年金
  • 固定资产需要具备的条件
  • 公司有主营业务收入没有主营业务成本
  • 销售收入用营业收入还是营业总收入
  • 公司如何做账本
  • 其他综合收益包括留存收益吗
  • mysql8.0 主从
  • fedora系统怎么设置停电关机
  • 微软星期二补丁KB3022345导致USB设备无法识别怎么办?
  • 无人值守安装操作系统
  • mm pp dpps进程
  • window7发布
  • xp如何一键还原系统还原
  • 如何安装windowsxp
  • linux使用rar命令压缩文件
  • win8.2系统
  • 缩放打印到一张a4纸上设置
  • python rgb转cmyk
  • cocos creator rpg
  • javascript新手教程
  • javascript面向对象编程指南
  • angular jsx
  • win10 python环境
  • jquery悬浮窗
  • div.remove
  • 多个javascript 合并
  • jquery.form.min.js
  • 如何将位置信息生成二维码
  • js如何保留一位小数
  • 全国国税税务机关是哪里
  • 税务局属于什么行业类别
  • 电子发票提取网站
  • 国家税务总局的官网
  • 税控系统减免税报表里
  • 山西省税务局网站系统维护公告
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设