位置: 编程技术 - 正文

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但各保留一个)

  • 税务登记证号是纳税人识别号吗?
  • 合同印花税怎么贴
  • 防伪税控系统专用设备
  • 滴滴出行怎么弄电子发票
  • 其他应收款包括应收利息吗
  • 开具银行资信证明
  • 固定资产新建帐套
  • 企业股权转让收入申报表填哪里
  • 补交本年增值税计提
  • 法人收到票据用什么抵扣
  • 项目部分回款是什么意思
  • 发行收入要减去股本吗
  • 通用机打发票现在还有吗
  • 员工扣款个税如何做账
  • 单位统一为员工办的银行卡属于对公账户吗
  • 原始凭证谁负责
  • 业务招待费进项税额转出
  • 进厂的政府补贴怎么拿
  • 业务招待费是什么科目
  • 升级win10到专业版
  • dolby audio设置
  • 发放工资的时候,如何在excel里快速查询未发放成功的
  • php下载限速
  • 房地产项目公司是什么意思
  • 奇托尔加赫城堡
  • 蔚蓝的海怎么样
  • php files
  • 销售产品应交的消费税分录
  • 空调拆卸安装怎么找师傅
  • 公司向股东借的钱怎么还
  • yolov3训练自己的数据超详细
  • 红嘴牛文鸟图片
  • thinkphp连接查询少数据
  • 期末余额跟年初余额是什么意思
  • dom-to-image原理
  • 预定义变量是什么
  • 目标追踪模型
  • 万能的python
  • php图像识别技术是什么
  • mysqldump语句
  • 国企无偿划转股权免印花税
  • 对公账户怎么打印
  • 已认证发票被作废
  • 帝国cms视频教程
  • 销售成本包括销售人员工资吗
  • 小型微利企业季度所得税怎么计算
  • sql server 2008数据库引擎等安装失败
  • 公司年度汇算清缴费用多少
  • 增值税和所得税不一致的说明
  • 提取法定盈余公积会计分录
  • 收到预付卡的发票是否可以报销呢?
  • 自用房产税计入什么科目
  • 无奖有票是什么意思
  • 理财利息计入什么科目
  • 新成立公司实收资本没到位该怎么做账
  • 公司销售部门购买产品
  • 账面净值什么意思
  • 未按照规定编制应急预案的,责令限期改正,可以处罚款
  • 车间管理人员工资属于间接费用吗
  • sqlserver 索引
  • windows如何创建桌面快捷方式
  • 因windowssystem32
  • Win10怎么设置高性能
  • windowsxp的安装方法
  • vrvarp.exe是什么
  • linux@ubuntu
  • ic_launcher.xml
  • windows预览0x80072ee2
  • Android游戏开发实践指南
  • javascript数据结构
  • 对于不回微信的人,这样做,尽显高情商!
  • js应用实例
  • 浅谈一下新冠的好处
  • js实现双击屏幕放大
  • jquery设置滚动条
  • js合并两个数组并排序
  • 武汉税务代理大概多少钱
  • 全年上缴个人所得税多少
  • 福利企业免税有哪些项目
  • 残疾人在国企有补贴吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设