首页  >  文章  >  数据库  >  如何在MySQL中选择一个随机子集然后按另一列排序?

如何在MySQL中选择一个随机子集然后按另一列排序?

Linda Hamilton
Linda Hamilton原创
2024-10-26 06:04:31680浏览

 How to Select a Random Subset and Then Order by Another Column in MySQL?

MySQL 中的随机选择和排序

查询 MySQL 数据库时,通常希望随机选择记录的子集。 ORDER BY RAND() 子句可用于实现此目的。但是,将此子句与其他排序子句组合时,考虑操作的顺序非常重要。

尝试选择记录的随机子集,然后按另一列对结果集进行排序时,会出现一个常见的陷阱。以下查询是一个示例:

SELECT * FROM users WHERE 1 ORDER BY RAND(), name ASC LIMIT 20

此查询的目的是从 users 表中随机选择 20 个用户,然后按名称列升序对他们进行排序。但是,此查询不会产生所需的结果。

原因是 ORDER BY RAND() 子句引入了非确定性排序。这意味着每次执行查询时结果的顺序都会改变。因此,后续的 name ASC 子句无法用于可靠地对结果进行排序。

为了正确地对结果进行排序,我们需要使用子查询。以下查询将随机选择 20 个用户,然后按名称列对他们进行排序:

SELECT * FROM 
(
    SELECT * FROM users ORDER BY RAND() LIMIT 20
) T1
ORDER BY name 

内部查询随机选择 20 个用户并将结果存储在临时表 T1 中。然后,外部查询从 T1 中选择所有行并按名称对它们进行排序。

以上是如何在MySQL中选择一个随机子集然后按另一列排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

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