
如何在 MySQL 中使用 GROUP BY?
不少开发者发现,MySQL 的 GROUP BY 语句并不总是严格要求将 SELECT 语句中所有的字段都包含在 GROUP BY 子句中。这究竟是怎么回事呢?
事实上,MySQL 的行为取决于 SQL_MODE 的设置。从 MySQL 5.7 开始,默认的 SQL_MODE 启用了 ONLY_FULL_GROUP_BY 选项。当此选项启用时,SELECT 语句中未出现在 GROUP BY 子句中的列必须在聚合函数(如 SUM、COUNT、AVG)中使用,否则会抛出错误。
天工AI
昆仑万维推出的国内首款融入大语言模型的AI对话问答、AI搜索引擎,知识从这里开始。
400 查看详情
不过,你可以通过手动调整 SQL_MODE 设置来禁用 ONLY_FULL_GROUP_BY 选项。禁用后,MySQL 不再检查 SELECT 语句中的列是否全部包含在 GROUP BY 子句中。
有关详细信息,请参阅 MySQL 5.7 参考手册:
MySQL :: MySQL 5.7 Reference Manual :: 1.3 What Is New in MySQL 5.7
以上就是MySQL 中的 GROUP BY 语句为什么有时不严格要求所有字段都包含在内?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/736476.html
微信扫一扫
支付宝扫一扫