位置: 编程技术 - 正文

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

  • 财务软件和报税软件区别
  • 社保的滞纳金放什么科目
  • 土地摊销全部计入成本吗
  • 股份支付为什么计入股本溢价
  • 公司名称房产和房地产区别
  • 长期股权投资会减值损失吗
  • 印花税申报成功后在哪里查询
  • 工程未完工但已开票
  • 运输过程中货物丢失
  • 收到认缴实收资本怎么做账务处理?
  • 分配利润和分配股利
  • 出纳如何登账
  • 营改增后租金如何交税
  • 增值税普通发票需要交税吗
  • 购进固定资产抵扣时咋填报增值税
  • 接待客户的住宿费账务处理
  • 年终奖需要计入工资交社保吗
  • 津贴证明是让单位开吗
  • 金蝶kis云专业版原材料数量怎么录入
  • 计提工资附加费啥意思
  • 烟酒专用发票能抵税吗
  • 上缴税金包括什么
  • 买免税产品
  • 怎么用苹果6splus
  • 基准收益率是
  • 开具的服务费怎么做分录
  • 收到投资分红怎么做账务处理?
  • 预收账款为什么不属于金融负债
  • 现金流量套期的分录
  • php文件怎么打开运行
  • 资产减值损失如何录入
  • tepac接口
  • 企业会计准则条文释义与案例详解
  • php全局变量和局部变量
  • php16进制
  • 联邦学习(FL)+差分隐私(DP)
  • 微信小程序开发一个多少钱
  • 毕业设计基础
  • 上海地铁9号线一期工程
  • 固定资产被替换的账面价值怎么算
  • 与上级往来的会计科目的题目
  • 净资产怎么增长
  • 小规模销售收入超过500万
  • 费用科目分别有什么
  • dedecms配置
  • 一般纳税人零申报报税流程
  • 金税盘技术维护费每年都减免么
  • sql server 2008打开界面
  • 结转全年利润总额
  • 建筑公司算不算企业
  • 金税四期查到了怎么办
  • 计提工资要附什么凭证
  • 以前年度损益调整是什么意思
  • 租赁存在的原因有哪些
  • 销售返利可以计入销售费用吗
  • 涉外收入申报单怎么填
  • 印花税怎么进行税种认定
  • 关于废止有关排污收费规章和规范性文件的决定
  • centos怎么配置ssh
  • windows7中ie浏览器怎么打开
  • mac双系统删除mac系统
  • 生成系统健康报告怎么弄
  • linux 内存文件夹
  • win7怎么删除wifi已连接过的网络
  • linux 多块硬盘虚拟成一块
  • cocos2d-x教程
  • [置顶]电影名字《收件人不详》
  • linux 指定动态库连接位置
  • 为什么要建立文明城市
  • 拦截器 aop
  • python获取文件内所有函数
  • 网页加载多个js文件冲突
  • javascript例题
  • 城市配套费需要什么资料
  • 安徽国家税务局网上办税平台
  • 换发票需要交钱吗
  • 集团收管理费开什么发票
  • 税务局查帐流程
  • 云南新农合怎么报销的
  • 印花税核定依据填写什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设