问题:
如何高效地从一个数组中选择指定数量的随机行大型表,而不使用潜在的资源密集型 ORDER BY RAND()方法?
答案:
MySQL 解决方案:
不使用 ORDER 从类“one”中选择 X 随机行BY RAND():
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(); ?>
此代码确定表行数内的随机偏移量,并使用它通过 LIMIT 选择指定数量的随机行,并且OFFSET 查询。
以上是如何在不使用 ORDER BY RAND() 的情况下从 MySQL 表中高效地选择随机行?的详细内容。更多信息请关注PHP中文网其他相关文章!