驚喜-這是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?它只是選擇一個。據(jù)我所知,它只是選擇找到的第一個Y。理由是,如果Y既不是聚合函數(shù)也不在group by子句中,則在查詢中指定“ select Y”是沒有道理的。因此,作為數(shù)據(jù)庫引擎的我將返回我想要的任何東西,而您會喜歡它。甚至還有一個MySQL配置參數(shù)來關閉這種“松散性”。 http://dev.mysql.com/doc/refman/5.7/zh-CN/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的理由是什么?
為什么MySQL允許沒有聚合功能的“分組”查詢?
搖曳的薔薇
2019-10-21 09:33:26