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

打印 上一主题 下一主题

主题 1034|帖子 1034|积分 3102

本文内容来自YashanDB官网,原文内容请见 https://www.yashandb.com/newsinfo/7610112.html?templateId=1718516
题目征象
以下SQL在MYSQL下均能执行乐成,在崖山下执行报错。
  1. SELECT Sname,Ssex, min(Sage) FROM Student group by Ssex;
  2. SELECT Sname,count(0) AS counts FROM Student;
  3. select
  4. min(st.Sage) ,
  5. SC.CId,
  6. min(st.SId),
  7. min(SC.score)
  8. from Student st LEFT JOIN SC ON st.SId = SC.SId
  9. group by SC.CId
  10. order by st.Sage
  11. ;
复制代码
MYSQL执行乐成:

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

原因
SQL-92 和更早版本不允许选择列表、HAVING条件或ORDER BY列表引用未在GROUP BY子句中命名的非聚合列的查询。例如,此查询在尺度 SQL-92 中是非法的,因为name选择列表中的非聚合列未出现在GROUP BY:
  1. SELECT Sname,Ssex, min(Sage) FROM Student group by Ssex;
复制代码
为了使查询在 SQL-92 中合法,Sname 必须从选择列表中去掉该列,或在 GROUP BY子句中命名该列。
SQL:1999 及更高版本允许如许的非聚合列出现在选择列中。
崖山和ORACLE在这个点都是及SQL-92为准。所以在崖上执行会报错。
办理办法
1、对于非聚合列出现在选择列中,MySQL是任取一行记载,改成用聚合函数来取最小或最大一行。
  1. SELECT min(Sname),Ssex, min(Sage) FROM Student group by Ssex;
  2. SELECT max(Sname),count(0) AS counts FROM Student;
复制代码
2、对于MySQL中group by 加 order by,可拆分2层,里面一层是group by,外面一层是order by
  1. SELECT
  2. *
  3. from (
  4. select
  5. SC.CId,
  6. min(st.Sage) as mage,
  7. min(st.SId),
  8. min(SC.score)
  9. from Student st LEFT JOIN SC ON st.SId = SC.SId
  10. group by SC.CId
  11. )
  12. order by mage
  13. ;
复制代码
总结
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

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

愛在花開的季節

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表