我的查询问题是从数据库中选择50行的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结果资源
答案 0 :(得分:1)
使用RAND()随机化顺序,然后选择限制0,100
order by rand() limit 0,100
在mysql中最快的方式
您可能希望阅读此替代http://jan.kneschke.de/projects/mysql/order-by-rand/ 按照该文章中提出的方式进行操作有一些限制
答案 1 :(得分:1)
如果表中的id是顺序的,为什么不生成介于0和“max_rows”之间的x个随机数。
然后执行类似
的操作 'SELECT ... FROM .... WHERE
ID为in (' . implode(',', $randomNumbers) . ')';
它将返回带有生成的id的行。
答案 2 :(得分:-1)
您可以使用:
SELECT ... FROM ... LIMIT $rand,100
其中$rand
是代码端随机生成的数字(0-50k)