令人惊讶的是--这是一个在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决裂的理由是什么?
https://stackoverflow.com/questions/1225144
复制相似问题