当前位置: 首页 > news >正文

【YashanDB知识库】如何将mysql含有group by的SQL转换成崖山支持的SQL

本文内容来自YashanDB官网,原文内容请见 https://www.yashandb.com/newsinfo/7610112.html?templateId=1718516

问题现象

以下SQL在MYSQL下均能执行成功,在崖山下执行报错。

SELECT Sname,Ssex, min(Sage) FROM Student group by Ssex;SELECT Sname,count(0) AS counts FROM Student;selectmin(st.Sage) ,SC.CId,min(st.SId),min(SC.score)from Student st LEFT JOIN SC ON st.SId = SC.SIdgroup by SC.CIdorder by st.Sage;

MYSQL执行成功:

崖山上执行报错:YAS-04316 not a single-group group function

原因

SQL-92 和更早版本不允许选择列表、HAVING条件或ORDER BY列表引用未在GROUP BY子句中命名的非聚合列的查询。例如,此查询在标准 SQL-92 中是非法的,因为name选择列表中的非聚合列未出现在GROUP BY:

SELECT Sname,Ssex, min(Sage) FROM Student group by Ssex;

为了使查询在 SQL-92 中合法,Sname 必须从选择列表中去掉该列,或在 GROUP BY子句中命名该列。

SQL:1999 及更高版本允许这样的非聚合列出现在选择列中。

崖山和ORACLE在这个点都是及SQL-92为准。所以在崖上执行会报错。

解决办法

1、对于非聚合列出现在选择列中,MySQL是任取一行记录,改成用聚合函数来取最小或最大一行。

SELECT min(Sname),Ssex, min(Sage) FROM Student group by Ssex;SELECT max(Sname),count(0) AS counts FROM Student;

2、对于MySQL中group by 加 order by,可拆分2层,里面一层是group by,外面一层是order by

SELECT*from (selectSC.CId,min(st.Sage) as mage,min(st.SId),min(SC.score)from Student st LEFT JOIN SC ON st.SId = SC.SIdgroup by SC.CId)order by mage;

总结

SQL-92 要求非group by 列不能单独出来在选择列中,比SQL:1999允许出现任选一行出现在选择列中,更严谨合理。

任选一行对于应用开发会造成疑惑,Oracle、PostgreSQL、崖山都是以SQL-92为准。MySQL 在5.7 及8.0之后的版本

默认也是以SQL-92为准, SQL_MODE默认设置为ONLY_FULL_GROUP_BY即SQL-92方式。

参考资料:

https://dev.mysql.com/doc/refman/8.4/en/group-by-handling.html

https://dev.mysql.com/doc/refman/8.4/en/group-by-modifiers.html

http://www.lryc.cn/news/504453.html

相关文章:

  • 希迪智驾持续亏损8.2亿:毛利率下滑,冲刺“自动驾驶矿卡第一股”
  • 部署GitLab服务器
  • 利用cnocr库完成中文扫描pdf文件的文字识别
  • pythonselenium自动化初始配置
  • 【C++】数的性质问题分析与优化
  • ASP.NET Core WebAPI中使用Jwt实现鉴权授权-System.IdentityModel.Tokens.Jwt
  • 【iOS】OC高级编程 iOS多线程与内存管理阅读笔记——自动引用计数(四)
  • 嵌入式软考学习笔记(1)超详细!!!
  • 【数据分享】2013-2023年我国省市县三级的逐年CO数据(免费获取\excel\shp格式)
  • C# 探险之旅:第十六节 - 整数类型:与八位数字精灵的奇幻舞会
  • Cleo文件传输软件存在任意文件读取漏洞(CVE-2024-50623)
  • Java 小抄|解析 JSON 并提取特定层级数据
  • 活动报名:Voice Agent 开发者分享会丨RTE Meetup
  • DOA估计算法——ESPRIT算法
  • CEF 数据加密与网络安全
  • go build command
  • 理解音频采样率和transformer模型:给Python小白的简单解释
  • 【RL Latest Tech】安全强化学习(Safe RL):理论、方法与应用
  • 大模型qiming面试内容整理-系统设计与架构
  • Mac/Windows端长期破解myBase8方法(无需安装火绒)
  • firewall
  • XSS(跨站攻击)
  • Tomcat添加各种响应头 X-Download-Options、Permissions-Policy等
  • 搭建Tomcat(一)---SocketServerSocket
  • ubuntu 使用 Times New Roman 字体在 Matplotlib 中绘图并调整字体大小
  • openGauss开源数据库实战二十三
  • MySQL 复合查询(重点)
  • ASP.NET |日常开发中连接Oracle数据库详解
  • java_连接数据库的方法_后端处理_前端调用_打通整体思路
  • 网络安全知识点