位置: 编程技术 - 正文

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

  • 应交增值税是什么意思
  • 文化传媒公司的税种及税率
  • 应付账款及预付账款分录
  • 税务局如何认定虚开
  • 企业所得税计提表模板
  • 月末怎么计提税费
  • 税控盘服务费抵减有效期几年
  • 去年开的专票今年可以作废吗
  • 三栏式明细账月结
  • 没经营的个体户营业执照怎么注销
  • 有发票章的存根联可以当发票用吗
  • 准予扣除的职工福利费
  • 房产税细节
  • 溢价收购全资子公司股票
  • 进项税发票已经认证但对方又作废
  • 实际结算金额超出出票金额,银行汇票要给收款人么
  • 收购公司收购款转给谁
  • 企业减免所得税
  • 资产负债表在建工程怎么填列
  • 网络销售平台优势有哪些
  • 销售利润率是什么能力指标
  • 不计入开办费可以吗
  • linux zen3
  • phpemail正则
  • 经营性流动负债计算公式
  • PHP:oci_field_is_null()的用法_Oracle函数
  • 固定资产清理的会计科目处理
  • windows默认网关应该设置为的地址
  • phpeach函数
  • 是谁唤醒你
  • 如何做世界上最小的遥控飞机
  • 企业常用的消毒措施有
  • 餐饮专用发票可抵扣吗
  • 偿还应付账款会使得资产报酬率增加吗
  • transformer中的token
  • 用友u8删除凭证的步骤
  • 员工持股平台合伙企业
  • mysql事件使用方法
  • 本年利润是净利润吗
  • 企业所得税不得核定征收行业
  • 如何用python绘制
  • 现金折扣什么时候冲减收入
  • 本月的费用
  • 房产原值是含税还是不含税
  • 作废的发票会统计到税额里吗
  • 长期资产的减值会影响CFO吗
  • 注册公司注册公司
  • mysql all
  • 商家的这些行为对消费者的购买行为有什么影响
  • 小规模普通发票怎么做分录
  • 销售收入发生变动的影响
  • 收到社保稳岗补贴需要交税吗
  • 职工薪酬纳税调整
  • 工程施工怎么做账
  • 其他应付款跨年了
  • 固定资产报废会议纪要模板
  • 跨年收入会计分录
  • 汇款退款
  • 银行承兑汇票记载事项
  • 实收资本应补缴哪些税
  • 为什么要计提工资附加费
  • 怎么设置账簿
  • sql语句优化的13种方法
  • Windows10安装包下载
  • window如何还原系统
  • xp系统连接共享文件夹
  • 苹果笔记本mac系列区别
  • win10错误提示
  • 11月 Win8.1 Update 3更新哪些内容?开始菜单依然没有
  • css教程实例
  • cocos怎么用
  • cocos creator js ts
  • node.js基础入门
  • 简单介绍linux系统有哪些主要特点?
  • 从零开始学什么
  • Android自定义控件开发入门与实战 百度网盘
  • 本年累计实际已预缴的所得税额怎么填
  • 从事农业种植是什么职业
  • 纳税信用等级在哪里查
  • 土地 荒
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设