【发布时间】:2013-05-31 08:22:54
【问题描述】:
我的查询从 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 结果资源
【问题讨论】:
-
以任意顺序获取所有行,然后在 PHP 中对其进行洗牌(或从结果数组中随机抽取一些)可能是正确的方法。
-
@MadaraUchiha,当我们实际上只需要 100 行时选择 50k 行并不是一个好主意
-
@v2p:没读好,我的错,你是对的。