位置: 编程技术 - 正文

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

  • 业务招待费可以进项抵扣吗
  • 增值税月末结转还是年末结转
  • 一般纳税人委托其他单位加工材料收回后直接对外销售的
  • 房产税的计税依据包含增值税吗
  • 城市维护建设税的计税依据是什么
  • 汇兑记载事项及使用注意事项
  • 什么是库存现金的盘亏
  • 增值税不含税销售额怎么计算
  • 定期定额不开票违法吗
  • 员工团体意外保险怎么报销
  • 专票当普票用,发票勾选怎么操作
  • 水利建设专项收入的计税依据是什么?
  • 处置可供出售金融资产取得的投资收益
  • 财务软件计提所得税分录
  • 财产理赔收入怎么做账
  • 免税产品的销项税
  • 关联方往来款项余额
  • 申报作废的多申报的退款怎么处理?
  • 饭店购买厨房用具分录
  • 关于城建税教育费附加地方教育附加的计算
  • 企业自产自用需要交增值税吗
  • 避税和不避税怎么选
  • 开房租发票交的税,因优惠政策退税,怎么账务处理
  • amdr5 1400
  • linux怎么下载安装腾讯Tim?
  • uniapp获取input的值
  • 收到法院的案件款应该怎么做帐
  • 进程控制块PCB不包括( )
  • 提前支付的费用记账
  • ntkrpamp.exe
  • 材料明细账的登记范本手写
  • Vue3 & app.use 与 install 函数的作用
  • php通用分页类
  • 深拷贝的实现方式
  • vue3+ts+vite
  • 长期股权投资的核算方法
  • 基于专业性的家校双向互动,需要家长的学校教育参与
  • qt opencv ffmpeg
  • php post数据
  • php数据库搭建
  • 代理费与代理运费的区别
  • mysql的间隙锁与排他锁
  • 商品流通企业物流成本的具体构成包括()
  • 子公司如何向母公司申请用印
  • 信用减值损失的借贷方向
  • 预付账款可以抵扣增值税么
  • 劳务分包的三种形式
  • 给客户退款怎么说
  • 视同销售是怎么回事?
  • 当月进货没有认证怎么办
  • 未按期预缴企业社保
  • 生产中产生的废油漆桶等危险废物应当作为什么贮存
  • 销售废旧物资账务处理
  • 企业安装电子监控收费吗
  • 应收账款如何做坏账
  • 开发项目设计费放入什么科目
  • 实缴资本和注册资本的比例
  • 在mysql中使用视图的限制不包括
  • 在sqlserver数据库中,执行sql语句
  • mysql优化实战
  • sqlserver 通用分页存储过程
  • 电脑开机显示xp后无反应
  • win7 64位系统无法使用银行网银怎么办? IE9浏览器无法使用农业银行网银的解决方法
  • win7系统任务栏跑到右侧怎么办
  • Windows(win7/win8/xp/2003)进入安全模式方法详细汇总
  • mac休眠怎么设置
  • w10系统怎么压缩
  • linux中修改命令
  • 在linux系统中,用来存在系统所需
  • win10搜索设置选项
  • js创建类对象的方法
  • Unity的WWW类的用法整理
  • js自定义指令
  • Python虚拟环境创建
  • 动态生成类对象
  • jquery找父级
  • 税务局要求补上年房租开票
  • 县级税务
  • 重庆国家税务局发票流向查询
  • 法规处职责要点和底线清单
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设