首页 >数据库 >mysql教程 >MySQL/MariaDB 子查询:为什么 ORDER BY 行为在新版本中发生变化?

MySQL/MariaDB 子查询:为什么 ORDER BY 行为在新版本中发生变化?

DDD
DDD原创
2024-12-31 12:59:17763浏览

MySQL/MariaDB Subqueries: Why Does ORDER BY Behavior Change in Newer Versions?

MySQL/MariaDB:子查询中的 Order by

MySQL 和 MariaDB 的最新版本在处理子查询中的 order by 操作方面引入了更改。

原创查询:

SELECT t2.Code from (select Country.Code from Country order by Country.Code desc ) AS t2;

问题:

在 MySQL 5.5 及更早版本中,上述查询按照指定的降序对子查询结果进行排序。然而,在较新版本的 MySQL 和 MariaDB 中,子查询结果不再默认按降序排序。

原因:

行为的变化是由于更严格的遵守 SQL 标准。根据标准,子查询结果是无序的行集。因此,在子查询中应用 order by 子句可能无法保证所需的排序。

解决方案:

要解决此问题,有两种推荐方法:

  • 最外层 Order By: 将 order by 子句应用于最外层 SELECT语句:
SELECT t2.Code from (select Country.Code from Country) AS t2 ORDER BY t2.Code DESC;
  • 子查询中的限制:如有必要,请在子查询中指定限制:
SELECT t2.Code from (select Country.Code from Country ORDER BY Country.Code DESC LIMIT 2) AS t2;

此确保子查询生成一组排序的结果,无论是否将 order by 子句应用于最外层SELECT.

记录的行为:

MariaDB 已正式记录此行为,指出 SQL 标准不允许在子查询中指定 order by 子句,并且应该这样做被视为一组无序的行。推荐的方法是将 order by 应用到最外层查询,或者在必要时使用限制。

以上是MySQL/MariaDB 子查询:为什么 ORDER BY 行为在新版本中发生变化?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn