位置: 编程技术 - 正文

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

  • 生育津贴是否需要申报免税所得
  • 企业给员工购买社保的规定
  • 个税新规定2021
  • 一般风险准备是留存收益吗
  • 春节补贴是加还是减
  • 往来票据如何开具
  • 餐饮业税务申报
  • 报销人和经办人怎么区分
  • 员工没工资,但缴纳了社保,需要申报吗
  • 小规模纳税人一个季度多少免税
  • 属于劳务分包合同
  • 政府收回土地使用权
  • 境内货代公司之间付美金
  • 增值税税负率怎么算
  • 最新契税优惠政策公告财政部
  • 专票地址错了可以报销吗
  • 什么时候计提减值
  • 软件服务费是什么
  • 民间非营利组织财务报表
  • 必要报酬率的计算公式Rm
  • 工会经费怎么申报,多久报一次
  • 收到其他公司的罚款会计分录
  • 公司备用金属于夫妻财产吗
  • 无形资产商标转让费计入什么科目
  • 一个集团的分公司干过活再去另一个分公司会被发现吗
  • 苹果手机微信怎么迁移聊天记录到新手机
  • mac更新内容
  • 汽车维修行业会计分录
  • 收入支出如何结转
  • 什么叫奖励旅游
  • php验证码扭曲效果怎么做
  • 兰溪园林绿化养护
  • 购买的固定资产退回账务处理
  • monolog php
  • php获取表单数据保存到mysql中
  • 增值税专用发票怎么开
  • 拨缴经费收入进行账务处理
  • 旋转 目标检测
  • php 后期静态绑定
  • 销售自己使用过的物品的税率
  • 工会经费的使用范围有哪些
  • 包装物为什么是无菌的
  • 税务发票红字发票怎么开
  • js闭包示例
  • c语言中asin
  • 自收自支编制和全额拨款编制
  • 小规模企业所得税怎么征收
  • 应付利息增加说明企业什么
  • 固定资产科目代码是多少
  • 生活服务的行业
  • 广告制作费怎么入账
  • 在途物资属于会计科目吗
  • 滴滴电子普通发票能抵扣进项税吗
  • 会计学材料成本差异
  • 差旅费所得税扣除标准2023
  • 在建工程抵押贷款的用途为在建工程继续建造所需资金
  • 公司股东的主要几种分类
  • 公司买护肤品发票如何入账
  • 房地产企业什么时候停止预缴增值税
  • 怎样才能制作出白瓷
  • 施工企业应收账款周转率多少合适
  • mysql语句性能优化
  • sql2000删除
  • mysql的子查询语句
  • mysql column is ambiguous
  • 为快捷方式建立快捷方式
  • linuxwindows差别
  • windows xp删除所有数据
  • 电脑开机绿
  • 查找返回一行数据
  • win7怎么查看电池信息
  • 修改linux系统用户密码
  • cocos2dx 3.5 ”hello world“解析
  • 获取jquery对象
  • angular scope
  • python xml.etree.ElementTree遍历xml所有节点实例详解
  • 一起学下载软件
  • ActivityManagerService (二)
  • 工行网银如何申请发票
  • 税务延期申报最长多久
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设