位置: 编程技术 - 正文

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

  • 电梯安装费发票
  • 税金及附加要扣除吗
  • 购车增值税可以抵扣多少
  • 免征增值税项目记忆
  • 不同税率的产品可以开一张票里吗
  • 装修增值税普通发票几个点
  • 输入开票码开具电子发票
  • 物业管理企业代管基金是什么
  • 纳税人提供植物油的税率
  • 企业如何做好税务管理工作
  • 专票当月未认证怎么处理
  • 保险公司的税收是多少
  • 保安费用分录
  • 老板垫付的钱应该怎么做科目
  • 预计负债的计量,如何确定最佳估计数
  • 固定资产进项税额转出怎么做账务处理
  • 动态路由协议rip配置实验心得
  • PHP:curl_pause()的用法_cURL函数
  • PHP:class_implements()的用法_spl函数
  • 资本公积和盈余公积的提取比例
  • 一般纳税人差额征税申报表怎么填
  • 资本化计入
  • 详解php字符串替换
  • php socket_create
  • 债务重组收益会计处理
  • 陶尔米纳电影节
  • 超像素和markpage的区别
  • 文件上传漏洞原因
  • sessionn
  • 员工休产假不发工资违法吗
  • 公司法关于公司变更后权利义务的规定
  • 普通发票作废要做账吗
  • 帝国cms如何使用
  • dedecms转eyoucms
  • 企业发生的汇兑差额
  • 股权转让需要开票吗怎么开
  • 实收资本属于限定性净资产吗
  • 加班餐费和误餐费的区别
  • 公司年度汇算清缴费用多少
  • 成品油办法废止后,加油站还需办理成品油许可证吗
  • 如果不签合同会怎么样
  • 如何在个人所得税app上修改扣缴义务人
  • 支付外债利息要代扣代缴哪几个税
  • 建筑企业提供服务的机制保障
  • 其它流动资产为负数原因
  • 固定资产清理包括什么会计科目
  • 新公司要建哪些项目
  • sql中的存储过程是干嘛用的
  • sql server索引怎么用
  • sqlserver函数大全
  • mysql修改版本号
  • centos7怎么关闭端口
  • 怎么快速隐藏电脑下方一排
  • xp系统打开浏览器没反应
  • 完美解决英语怎么说
  • windowsxp删除所有内容
  • Windows Server 2008使用软件授权管理工具
  • watch programmes
  • mac 设置
  • windows7怎么说
  • 常见unix操作系统
  • win7桌面点不了怎么回事
  • cad90度角
  • win7集成补丁教程
  • Win10预览版拆弹
  • cocos2dx用checkbox实现单选框和button实现table按钮
  • vue条形码
  • 开快打开
  • js原型继承和构造继承
  • Node.js+jade+mongodb+mongoose实现爬虫分离入库与生成静态文件的方法
  • python介绍的主要内容
  • javascript面向对象精要pdf
  • js怎么拿到表单提交数据
  • 出租车票真伪查询官网
  • 人力资源差额发票
  • 税务局国际税收亮点工作总结
  • 浙里办扫码在哪里
  • 10%加计抵减政策条件
  • 混合销售定义是什么意思
  • 罗湖税务局在哪
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设