在 MySQL 中,您可能会遇到允许使用如下视图的场景:
SELECT AVG(table_name.col1), AVG(table_name.col2), AVG(table_name.col3), table_name.personID, table_name.col4 FROM table_name GROUP BY table_name.personID;
此查询包含 col1、col2 和 col3 的聚合函数,但它还选择col4 没有任何聚合。通常,这样的查询在 Microsoft SQL Server 等其他数据库系统中会被视为无效。
然而,在 MySQL 中,这种行为是允许的。理解原因很重要:
在 GROUP BY 查询中选择非聚合列时,MySQL 会从组中选择任意值。这通常对应于组中第一个存储的行的值。
此功能可能会导致不明确的查询,其中非聚合列的选定值可能会有所不同按照组中行的顺序。例如,下面的查询可能会根据行排序为同一 personID 返回不同的 col4 值:
SELECT AVG(table1.col1), table1.personID, persons.col4 FROM table1 JOIN persons ON (table1.personID = persons.id) GROUP BY table1.personID;
为了避免歧义,选择功能上的列至关重要取决于 GROUP BY 标准中的列。这意味着对于分组列的每个唯一值,“不明确”列应该只有一个可能的值。
MySQL 提供 ONLY_FULL_GROUP_BY SQL 模式,该模式可以启用使 MySQL 遵守 ANSI SQL 标准。在此模式下,在 GROUP BY 查询中选择非聚合列将导致错误,除非这些列在功能上依赖于分组列。
虽然 MySQL 允许选择非聚合列由于 GROUP BY 查询中的聚合列,必须意识到可能出现不明确的结果。为了确保确定性查询,建议将它们重写为按功能相关列明确分组或启用 ONLY_FULL_GROUP_BY 模式。
以上是为什么 MySQL 允许在 GROUP BY 查询中使用非聚合列?的详细内容。更多信息请关注PHP中文网其他相关文章!