位置: 编程技术 - 正文

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

  • 进项税抵扣怎么做账
  • 企业的其他业务收入包括哪些
  • 超率累进税率有哪些税种呢怎么算
  • 投资性房地产在非货币性资产交换怎么处理
  • 领发票凭证做什么用
  • 个体工商户免征税额度是多少
  • 增值税税控系统专用设备
  • 个体工商户销售自己使用过的物品
  • 出售无形资产的会计科目
  • 印花税减免性质代码和项目名称小规模
  • 简易计税核算方法有哪些
  • 2017年8月1日到现在多少天
  • 金税盘用户管理是灰色不能点击
  • 2019年小规模纳税人免征增值税政策
  • 2021年如何申报海外收入
  • 房屋维修费属于固定资产吗
  • itunes无法链接
  • 收到服务费专票怎么做账
  • 公司多交的公积金能退吗
  • php header refresh
  • 咨询服务费需要什么附件
  • 除了个税还有什么税
  • 交房产税要带身份证嘛
  • 补交社保如何做账务处理
  • 什么是产品生产者之间争取最有利的关系
  • 直接计入当期利润的利得和损失有哪些
  • 混凝土简易计税能抵扣么
  • 进货开了发票也写了购销合同要交印花税吗
  • 运输费属于燃料费用吗
  • 注册资金抽回
  • 10分钟学会万用表
  • 对标是啥
  • 前端vue面试题2020
  • 实现扩展功能的快捷键
  • CSDN接入AIGC辅助创作,对此你怎么看?
  • 个人的无形资产
  • 销售蔬菜企业怎么做
  • 个税申报不成功,累计减除费用60000审核不通过
  • 当月认证的发票可以撤销吗
  • php sql 教程
  • 对公账户分类及区别
  • 利润分配会计处理例题
  • 损益类科目的账务处理
  • 工程分包合同协议书
  • 二手车需要交什么
  • 失控发票多久能查出
  • 留抵会计分录
  • 股权转让溢价部分会计分录
  • 小规模红冲发票怎么做分录
  • 发放奖金怎么做账
  • 进项已抵扣,退货发票怎么处理
  • 零售行业折扣销售方案
  • 银行的手续费开票怎么开
  • 销售费用和管理费用的税前扣除
  • 子公司内部交易
  • 调整去年管理费用怎么做分录
  • 差旅费报销属于自制原始凭证吗
  • win2003服务器管理
  • win7系统怎么连接
  • windows一体机
  • Windows虚拟机怎么打开
  • 如何升级win
  • linux 安装指令
  • linux deploy 无root
  • 80端口被system 占用解决方法
  • 如何深度理解
  • 在dos中文件是以什么目录结构
  • netcfghlp怎么安装
  • android下拉刷新上拉加载
  • unity3d4个脚本
  • 基于jQuey实现鼠标滑过变色(整行变色)
  • javascript深入理解
  • jQuery Timelinr实现垂直水平时间轴插件(附源码下载)
  • 安卓手机管家推荐
  • 如何判断安卓手机
  • python 网络编程总结
  • 国税发票打印汇总怎么弄
  • 中华人民共和国刑法
  • 公积金提取需要几个工作日
  • 留抵税额怎么形成的
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设