1

我的查询从具有 50k 行的数据库中选择 100 个随机行时遇到问题。

首先我只使用了函数 RAND() 但这变得太慢了。

现在我正在使用这个查询:

$query = mysql_query("SELECT t1.* FROM users AS t1 JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM users WHERE picture != '' && age <= 50 && age >= 18 && username != '')) AS id) AS t2 WHERE picture != '' && age <= 50 && age >= 18 && username != '' && t1.id >= t2.id LIMIT 100");
while($q = mysql_fetch_assoc($query)) 
{ echo $q['id'].'<br>'; }

但有时它会给出一堆空行。

谁能告诉我出了什么问题?

谢谢!

更新我也在尝试这个查询,但它给了我一个错误。

$query = mysql_query("SELECT id FLOOR(1 + RAND() * x.m_id) 'rand_ind' FROM users (SELECT MAX(t.id) - 1 'm_id' FROM users t) x WHERE picture != '' && age <= 50 && age >= 18 && username != '' ORDER BY rand_ind LIMIT 100");

mysql_fetch_assoc():提供的参数不是有效的 MySQL 结果资源

4

3 回答 3

1

使用 RAND() 随机化订单,然后选择限制 0,100

order by rand() limit 0,100

在mysql中最快的方法

您可能想阅读此替代品http://jan.kneschke.de/projects/mysql/order-by-rand/ 尽管按照该文章中建议的方式进行操作有一些限制

于 2013-05-31T08:27:32.180 回答
1

如果您在表中的 id 是连续的,为什么不只生成 0 到“max_rows”之间的 x 个随机数。

然后做类似的事情

'SELECT ... FROM .... WHEREIDin (' . implode(',', $randomNumbers) . ')';

它将返回具有生成 id 的行。

于 2013-05-31T08:33:34.760 回答
-1

你可以使用:

SELECT ... FROM ... LIMIT $rand,100

$rand从代码端随机生成的数字(0-50k)在哪里

于 2013-05-31T08:26:26.737 回答