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 子句可能无法保证所需的排序。
解决方案:
要解决此问题,有两种推荐方法:
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中文网其他相关文章!