1.order by rand()
數(shù)據(jù)多了極慢,隨機性非常好,適合非常小數(shù)據(jù)量的情況。
復(fù)制代碼 代碼如下:
SELECT * FROM table_name AS r1 JOIN (SELECT (ROUND(RAND() * (SELECT ABS(MAX(id)-MIN(id)-$limit) FROM table_name))+(SELECT MIN(id) from table_name)) AS id) AS r2 WHERE r1.id >= r2.id ORDER BY r1.id ASC LIMIT $limit;
復(fù)制代碼 代碼如下:
SELECT FLOOR(7 + (RAND() * 6));
select * from test where rand()>0.0005 limit 10;
0.0005是一個計算出的比例直接關(guān)系到隨機的質(zhì)量,比如數(shù)據(jù)表10000條數(shù)據(jù),需要隨機取300條,那么0.0005就需要改成(300/10000=0.03)。
這種方法不能保證每次能取到多少,需要取多次。
2和3速度一樣的快,主要區(qū)別是2總能返回limit條數(shù)據(jù),3就沒準(zhǔn)了(符合正太分布)。2是連續(xù)數(shù)據(jù),3是隨機行。
新聞熱點
疑難解答
圖片精選