荪俗 发表于 2025-6-10 23:48:08

【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;



select

min(st.Sage) ,

SC.CId,

min(st.SId),

min(SC.score)

from Student st LEFT JOIN SC ON st.SId = SC.SId

group by SC.CId

order 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 (

select

SC.CId,

min(st.Sage) as mage,

min(st.SId),

min(SC.score)

from Student st LEFT JOIN SC ON st.SId = SC.SId

group 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

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

数察啜 发表于 2026-1-20 01:21:02

这个好,看起来很实用

嗦或 发表于 2026-1-23 09:37:28

不错,里面软件多更新就更好了

空娅芬 发表于 2026-1-23 10:56:54

新版吗?好像是停更了吧。

拼潦 发表于 2026-1-27 07:08:35

不错,里面软件多更新就更好了

尚腱埂 发表于 2026-1-27 07:12:14

谢谢分享,辛苦了

少屠 发表于 2026-2-3 07:38:57

感谢发布原创作品,程序园因你更精彩

幌斛者 发表于 2026-2-4 07:08:42

前排留名,哈哈哈

眩疝诺 发表于 2026-2-4 10:09:39

东西不错很实用谢谢分享

请蒂 发表于 2026-2-7 03:09:23

用心讨论,共获提升!

姨番单 发表于 2026-2-7 17:00:32

喜欢鼓捣这些软件,现在用得少,谢谢分享!

呼延含玉 发表于 2026-2-8 13:03:03

收藏一下   不知道什么时候能用到

喳谍 发表于 2026-2-9 18:15:37

喜欢鼓捣这些软件,现在用得少,谢谢分享!

痕厄 发表于 2026-2-10 00:00:25

感谢发布原创作品,程序园因你更精彩

贡醮 发表于 2026-2-10 14:44:09

感谢,下载保存了

猷浮 发表于 2026-2-10 22:16:20

分享、互助 让互联网精神温暖你我

喳谍 发表于 2026-2-12 01:44:22

谢谢分享,试用一下

郦惠 发表于 2026-2-12 06:02:20

前排留名,哈哈哈

寿爹座 发表于 2026-2-27 11:34:07

这个有用。

强怀梅 发表于 2026-3-9 17:32:11

这个有用。
页: [1]
查看完整版本: 【YashanDB知识库】如何将mysql含有group by的SQL转换成崖山支持的SQL