<bdo id='z55tj'></bdo><ul id='z55tj'></ul>

        <tfoot id='z55tj'></tfoot>

        <i id='z55tj'><tr id='z55tj'><dt id='z55tj'><q id='z55tj'><span id='z55tj'><b id='z55tj'><form id='z55tj'><ins id='z55tj'></ins><ul id='z55tj'></ul><sub id='z55tj'></sub></form><legend id='z55tj'></legend><bdo id='z55tj'><pre id='z55tj'><center id='z55tj'></center></pre></bdo></b><th id='z55tj'></th></span></q></dt></tr></i><div id='z55tj'><tfoot id='z55tj'></tfoot><dl id='z55tj'><fieldset id='z55tj'></fieldset></dl></div>

        <legend id='z55tj'><style id='z55tj'><dir id='z55tj'><q id='z55tj'></q></dir></style></legend>

        <small id='z55tj'></small><noframes id='z55tj'>

        MySQL GROUP BY 行为

        MySQL GROUP BY behavior(MySQL GROUP BY 行为)
      1. <legend id='tohN3'><style id='tohN3'><dir id='tohN3'><q id='tohN3'></q></dir></style></legend>
        • <bdo id='tohN3'></bdo><ul id='tohN3'></ul>
            <tbody id='tohN3'></tbody>

            1. <tfoot id='tohN3'></tfoot>
                <i id='tohN3'><tr id='tohN3'><dt id='tohN3'><q id='tohN3'><span id='tohN3'><b id='tohN3'><form id='tohN3'><ins id='tohN3'></ins><ul id='tohN3'></ul><sub id='tohN3'></sub></form><legend id='tohN3'></legend><bdo id='tohN3'><pre id='tohN3'><center id='tohN3'></center></pre></bdo></b><th id='tohN3'></th></span></q></dt></tr></i><div id='tohN3'><tfoot id='tohN3'></tfoot><dl id='tohN3'><fieldset id='tohN3'></fieldset></dl></div>

                  <small id='tohN3'></small><noframes id='tohN3'>

                • 本文介绍了MySQL GROUP BY 行为的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  给定下表'foo'

                  ID | First Name | Last Name
                  ----------------------------
                  67   John        Smith
                  ----------------------------
                  67   Bill        Jacobs
                  

                  以下查询将返回什么 first_namelast_name 以及为什么?

                  What first_name and last_name will the following query return and why?

                  SELECT * FROM foo WHERE ID = 67 GROUP BY ID
                  

                  推荐答案

                  MySQL 任意选择一行.在实践中,常用的 MySQL 存储引擎返回组中第一行的值,相对于物理存储.

                  MySQL chooses a row arbitrarily. In practice, commonly used MySQL storage engines return the values from the first row in the group, with respect to the physical storage.

                  create table foo (id serial primary key, category varchar(10));
                  
                  insert into foo (category) values 
                    ('foo'), ('foo'), ('foo'), ('bar'), ('bar'), ('bar');
                  
                  select * from foo group by category;
                  
                  +----+----------+
                  | id | category |
                  +----+----------+
                  |  4 | bar      |
                  |  1 | foo      |
                  +----+----------+
                  

                  其他人认为 MySQL 允许您运行此查询是正确的,即使它具有任意且可能具有误导性的结果.SQL 标准和大多数其他 RDBMS 供应商都不允许这种含糊不清的 GROUP BY 查询.这称为单值规则:选择列表中的所有列必须明确属于 GROUP BY 条件的一部分,或者在聚合函数内,例如COUNT()MAX()

                  Other folks are correct that MySQL allows you to run this query even though it has arbitrary and potentially misleading results. The SQL standard, and most other RDBMS vendors, disallow this kind of ambiguous GROUP BY query. This is called the Single-Value Rule: all columns in the select-list must be explicitly part of the GROUP BY criteria, or else inside an aggregate function, e.g. COUNT(), MAX(), etc.

                  MySQL 支持 SQL 模式 ONLY_FULL_GROUP_BY 如果您尝试运行违反 SQL 标准语义的查询,这会使 MySQL 返回错误.

                  MySQL supports a SQL mode ONLY_FULL_GROUP_BY that makes MySQL return an error if you try to run a query that violates SQL standard semantics.

                  AFAIK,SQLite 是唯一允许分组查询中有歧义列的其他 RDBMS.SQLite 返回组中最后行的值:

                  AFAIK, SQLite is the only other RDBMS that allows ambiguous columns in a grouped query. SQLite returns values from the last row in the group:

                  select * from foo group by category;
                  
                  6|bar
                  3|foo
                  

                  <小时>

                  我们可以想象那些不会有歧义但仍然违反 SQL 标准语义的查询.


                  We can imagine queries that would not be ambiguous, yet still violate the SQL standard semantics.

                  SELECT foo.*, parent_of_foo.* 
                  FROM foo JOIN parent_of_foo 
                    ON (foo.parent_id = parent_of_foo.parent_id) 
                  GROUP BY foo_id;
                  

                  没有合乎逻辑的方法会产生模棱两可的结果.foo 中的每一行都有自己的组,如果我们 GROUP BY foo 的主键.所以来自 foo 的任何列在组中只能有一个值.如果组是由 foo 的主键定义的,那么即使连接到由 foo 中的外键引用的另一个表,每个组也只能有一个值.

                  There's no logical way this could produce ambiguous results. Each row in foo gets its own group, if we GROUP BY the primary key of foo. So any column from foo can have only one value in the group. Even joining to another table referenced by a foreign key in foo can have only one value per group, if the groups are defined by the primary key of foo.

                  MySQL 和 SQLite 相信您可以设计逻辑上明确的查询.正式地,选择列表中的每一列都必须是 GROUP BY 条件中的列的功能依赖.如果你不遵守这一点,那是你的错.:-)

                  MySQL and SQLite trust you to design logically unambiguous queries. Formally, every column in the select-list must be a functional dependency of the columns in the GROUP BY criteria. If you don't adhere to this, it's your fault. :-)

                  标准 SQL 更加严格并且不允许一些可能明确的查询——可能是因为它对于 RDBMS 来说太复杂而无法确定.

                  Standard SQL is more strict and disallows some queries that could be unambiguous--probably because it would be too complex for the RDBMS to be sure in general.

                  这篇关于MySQL GROUP BY 行为的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Bogus foreign key constraint fail(虚假外键约束失败)
                  how to get last insert id after insert query in codeigniter active record(如何在codeigniter活动记录中插入查询后获取最后一个插入ID)
                  Force InnoDB to recheck foreign keys on a table/tables?(强制 InnoDB 重新检查表/表上的外键?)
                  How to auto generate migrations with Sequelize CLI from Sequelize models?(如何使用 Sequelize CLI 从 Sequelize 模型自动生成迁移?)
                  Clear MySQL query cache without restarting server(无需重启服务器即可清除 MySQL 查询缓存)
                  ALTER TABLE to add a composite primary key(ALTER TABLE 添加复合主键)
                  • <small id='bfeko'></small><noframes id='bfeko'>

                    1. <tfoot id='bfeko'></tfoot>
                    2. <legend id='bfeko'><style id='bfeko'><dir id='bfeko'><q id='bfeko'></q></dir></style></legend>
                      <i id='bfeko'><tr id='bfeko'><dt id='bfeko'><q id='bfeko'><span id='bfeko'><b id='bfeko'><form id='bfeko'><ins id='bfeko'></ins><ul id='bfeko'></ul><sub id='bfeko'></sub></form><legend id='bfeko'></legend><bdo id='bfeko'><pre id='bfeko'><center id='bfeko'></center></pre></bdo></b><th id='bfeko'></th></span></q></dt></tr></i><div id='bfeko'><tfoot id='bfeko'></tfoot><dl id='bfeko'><fieldset id='bfeko'></fieldset></dl></div>

                            <tbody id='bfeko'></tbody>
                          • <bdo id='bfeko'></bdo><ul id='bfeko'></ul>