mysql - 为什么 MySQL 允许没有聚合函数的 "group by"查询?

惊喜——这是 MySQL 中一个完全有效的查询:

select X, Y from someTable group by X

如果您在 Oracle 或 SQL Server 中尝试此查询,您会收到自然错误消息:

Column 'Y' is invalid in the select list because it is not contained in 
either an aggregate function or the GROUP BY clause.

那么 MySQL 如何确定为每个 X 显示哪个 Y?它只会选择一个。据我所知,它只会选择它找到的第一个 Y。基本原理是,如果 Y 既不是聚合函数也不是 group by 子句,那么在查询中指定“select Y”一开始就没有意义。因此,我作为数据库引擎会返回任何我想要的,你会喜欢的。

甚至还有一个 MySQL 配置参数可以关闭这种“松散”。 http://dev.mysql.com/doc/refman/5.7/en/sql-mode.html#sqlmode_only_full_group_by

这篇文章甚至提到了 MySQL 在这方面是如何被批评为不符合 ANSI-SQL 的。 http://www.oreillynet.com/databases/blog/2007/05/debunking_group_by_myths.html

我的问题是:为什么 MySQL 是这样设计的?他们放弃 ANSI-SQL 的理由是什么?

最佳答案

根据this page (5.0在线手册),它是为了更好的性能和用户的方便。

关于mysql - 为什么 MySQL 允许没有聚合函数的 "group by"查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1225144/

相关文章:

sql - MySQL:比较两个表之间的差异

mysql - 如何在不丢失列数据的情况下更改 MySQL 表的列位置?

mysql - 无法通过 phpmyadmin 导入数据库 文件过大

sql - MySQL GROUP BY 两列

mysql - InnoDB 需要一个多小时来导入 600MB 文件,MyISAM 在几分钟内

mysql - MySQL中给定子字符串的最后一个索引

sql - 从表中删除所有

sql - 如何查找具有包含小写字母的值的行

mysql - 我的 SQL 有什么问题? #1089 - 不正确的前缀键

python - 如何将数据插入 MySQL 数据库?