位置: 编程技术 - 正文

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

  • 广告费业务宣传费扣除标准
  • 增值税税额怎么算出来
  • 印花税的纳税人是买方还是卖方
  • 补缴以前年度增值税以及滞纳金
  • 基本户借款 一般户可以还吗
  • 进项税加计扣除什么时候开始的
  • 记载资金的账簿要交印花税吗
  • 基金投资债券会赔吗
  • 销售额负数 如何填报报表
  • 企业清算时未抵扣的进项税账务处理
  • 拿租金抵押金如何做账?
  • 转账支票背书有时间限制吗
  • 什么费用需要进行摊销
  • 应付账款多付了
  • 企业零申报教学视频
  • 利息股息红利个税如何计算
  • 应收未收的利息如何处理
  • 公司为员工购买五险一金是什么意思
  • 普通硅酸盐水泥和矿渣硅酸盐水泥的区别
  • 以前年度亏损可以税前扣除吗
  • 融资租赁要怎么做
  • 公司账户转入另一个公司的投资款怎么做账?
  • 长期驻扎外地的员工
  • 职工赔偿金的账务处理
  • 微软输入法繁体字变简体字
  • PHP:mb_ereg_search_init()的用法_mbstring函数
  • 收到专利补助费的会计处理
  • 什么是资产负债率,如何计算
  • PHP:imagesetstyle()的用法_GD库图像处理函数
  • 银行存款利息是按月结还是按年
  • 餐饮企业库存盘点表
  • 个人出售二手房要交增值税吗
  • 现金折扣发生销售退回
  • python模拟微信
  • 记账凭证和原始凭证都是登记账簿的直接依据
  • 现金流量表期初现金余额本年累计
  • php socket_create
  • yolov5tiny
  • Sklearn GridSearchCV跑SVM很慢或卡死解决办法,SVM线性核函数卡死
  • 前端程序员和后端程序员哪个工资高
  • php异常处理方法
  • git主干
  • 工会经费的使用范围有哪些
  • 租赁增值税发票税率
  • 未开票收入是否含税
  • 个人在平台销售怎么做
  • 工资薪金个人所得税在哪里申报
  • 原材料盘盈会计处理
  • mysql@变量
  • sql server2014教程
  • 发票收款人和复核人在哪儿政
  • 记账凭证后面附什么原始凭证
  • 来料加工的增值税怎么核算
  • 合同权利义务包含债务吗
  • 航天金税服务费发票在哪打印
  • 工资扣水电费怎么做账
  • SQL Server在AlwaysOn中使用内存表的“踩坑”记录
  • win7系统的笔记本电脑有哪些
  • windows xp安装win32程序
  • pps是什么文件
  • micc是什么意思中文
  • windows7开机
  • win8.1技巧
  • win10系统中怎么安装安卓应用
  • window8系统ie浏览器在哪里
  • nodejs中的事件循环的执行顺序
  • 深入浅出讲解es63
  • android学习路线
  • js实现功能
  • android获取手机的基本信息
  • 简述使用jquery实现表单验证的流程
  • android简单app实例
  • 国家税务总局河南省税务平台
  • 税务局把我拉入黑名单了怎么办
  • 国税局云南省税务局
  • 全国哪些地区社保比例高
  • 电脑上怎么登录个人网络
  • 纳税申报2020年2月
  • 安徽省税务干部学校
  • 高端护肤品品牌排行榜
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设