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中文网其他相关文章!