位置: 编程技术 - 正文

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

  • 应交所得税的计算公式
  • 个体定期定额怎么征税2023
  • 小规模纳税人免征增值税怎么记账
  • 增值税征税范围中销售应税服务包括什么服务
  • 小规模纳税人季度申报
  • 小规模人力资源外包税率
  • 注册了公司没有经营会怎么样
  • 电子发票和纸质发票哪个好
  • 企业所得税营业收入包括什么
  • 盈余公积可用于集体福利吗
  • 公司购入货架如何做账
  • 网店会计的工作内容是什么
  • 营改增广告标牌制作的税务怎么处理
  • 学校付学生的现金奖励入什么科目
  • 延期付款利息的税率是多少
  • 2018手写发票何时失效?
  • 房地产经常发生的法律问题
  • 法人借款可以做到短期借款吗
  • fat文件系统包括
  • 预计应收账款余额
  • 服务外包企业
  • 住房补贴缴纳比例是多少
  • 固定资产的主要特征有哪些
  • 缴纳房产税需要扣除折旧吗
  • 挂靠借用资质账务处理?
  • axios入门
  • 医院装修设计费用取费标准表
  • 琥珀山庄位于我国哪个省
  • 差旅费车票抵扣的相关规定
  • 公司法人往公司账户转钱会计分录
  • sklearn报错
  • 模型怎么部署
  • 帝国cms安装教程
  • 苗木增值税税率
  • 抵债资产怎么入账
  • 我们现在收到的礼物
  • 取得不规范发票的处理
  • js对象模型是什么
  • mac os x10.9.5
  • 零售行业bi
  • 生产成本设置二级科目
  • 装修消防改造费用会计分录
  • SQL Server 2008 R2 为用户权限分配的操作步骤
  • 命令行启动服务service
  • 利润分配怎么分配比例
  • 视同销售包括哪些行为?
  • 企业之间无偿使用资金涉税
  • 委托出口由谁办理退税
  • 销售款退回会计分录
  • 其它应付款为负
  • 企业会计档案由谁保管
  • 固定资产折旧年限的最新规定2023
  • 所得税费用如何计提
  • 敬老院的会计科目
  • 主键自增长的数据如何导入
  • sql server使用教程
  • mysql如何输入数据
  • 苹果15手机价格和图片颜色
  • WIN10系统中断
  • 如何查看苹果mac系统
  • win8怎么调整显示器亮度
  • win8系统开机启动项怎么设置
  • CentOS 6.x 到 CentOS 7 的升级过程
  • linux系统稳定
  • 戴尔笔记本自带win7系统盘重装系统
  • freebsd连接wifi
  • 代码结构说明书
  • pythonmatch函数
  • UNITY开发数字孪生
  • opengl入门教程
  • Nodejs sublime text 3安装与配置
  • jquery 写文件
  • 苹果多点触控
  • 优化ui界面是啥意思
  • js 显示当前时间
  • 工商跟税务的区别
  • 云南发票网站
  • 深圳国税税发票在哪里开
  • 陕西省西安市国家民用航天产业基地邮编
  • 用户卡,税控卡怎么办理
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设