使用 MySQL 选择随机行:详细解决方案
经常出现的问题是如何从大型 MySQL 表中有效地选择随机行,而无需求助于 ORDER BY RAND() 方法,众所周知,该方法对于较大的数据集效率较低。为了应对这一挑战,让我们探索一个可行的解决方案:
基于 MySQL 的方法:
利用以下 SQL 语句的组合:
SET @r := (SELECT FLOOR(RAND() * (SELECT COUNT(*) FROM mytable))); SET @sql := CONCAT('SELECT * FROM mytable LIMIT 1 OFFSET ', @r); PREPARE stmt1 FROM @sql; EXECUTE stmt1;
此方法涉及:
基于 PHP 的方法:
如果您喜欢工作使用 PHP,您可以使用以下代码片段:
<?php $mysqli->begin_transaction(); $result = $mysqli->query("SELECT COUNT(*) FROM mytable"); $row = $result->fetch_row(); $count = $row[0]; $offset = mt_rand(0, $count); $result = $mysqli->query("SELECT * FROM mytable LIMIT 1 OFFSET $offset"); ... $mysqli->commit();
此方法需要:
以上是如何从大型 MySQL 表中高效地选择随机行?的详细内容。更多信息请关注PHP中文网其他相关文章!