RAND()的多行选择


Multiple rows alternative for RAND()

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

首先,我只使用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>'; }

但有时它会给出一堆空行

谁能告诉我出什么事了?

谢谢!

UPDATE我正在尝试这个查询,但它给了我一个错误。

$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结果资源

使用RAND()随机排序,然后选择limit 0,100

order by rand() limit 0,100

mysql中最快的方法

您可能需要阅读这篇文章以获取替代方案http://jan.kneschke.de/projects/mysql/order-by-rand/文章中建议的方法有一些限制

如果表中的id是连续的,为什么不直接生成0到"max_rows"之间的x个随机数呢?

然后输入

'SELECT ... FROM .... WHERE id in (' . implode(',', $randomNumbers) . ')';

它将返回生成id的行。

您可以使用:

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

式中$rand为代码侧随机生成数(0-50k)