1.order by rand()
資料多了極慢,隨機性非常好,適合非常小資料量的情況。
複製** **如下:
select * from table_name as r1 join (select (round(rand() * www.cppcns.com(select abs(max(id)-min(id)-$limit) from table_name))+(select min(id) from table_nawww.cppcns.comme)) as id) as r2 where r1.id >= r2.id order by r1.id asc limit $limit;
速度非常快,但是得到的資料是id連續的,沒辦法解決。
子查詢產生乙個隨機數。
rand()是0到1的隨機數,可以等於0到1。
max(id)-min(id)還要要減去$limit以免結果數量不夠$limit條
因為主表id可能不連續,所以r1.id=r2.id
還要注意的是有時候最小id不是從1開始的,可能從乙個很大的數開始,所以必須加上m(id)的值
手冊相關內容:若要在i ≤ r ≤ j 這個範圍得到乙個隨機整數r ,需要用到表示式 floor(i + rand() * (j – i + 1))。
例如, 若要在7 到 12 的範圍(包括7和12)內得到乙個隨機整數, 可使用以下語句:
複製** **如下:
select floo + (rand() * 6));
select * from test where rand()>0.0005 limit 10;
0.0005是乙個計算出的比例直接關係到隨機的質量,比如資料表10000條資料,需要隨機取300條,那麼就需要改成(300/10000=0.03)。
這種方法不能保證每次能取到多少,需要取多次。
2和3速度一樣的快,主要區別是2總gbsgjcs能返回limit條資料,3就沒準了(符合正太分布)。2是連續資料,3是隨機行。
本文標題: mysql獲取隨機資料的方法
本文位址:
MySQL獲取隨機數
如何通過mysql在某個資料區間獲取隨機數?mysql本身提供乙個叫rand的函式,返回的v範圍為0 v 1.0。介紹此函式的mysql文件也介紹道,可以通過此計算公式floor i rand j i 獲取i v j的隨機數字v。為了書寫 呼叫方便,寫乙個函式返回隨機數字,注意,此函式為了遵應個人習...
獲取隨機數方法
其實獲取隨機數是微軟自帶的的乙個內建函式。很簡答,但是在使用的時候發現經常有重複 的資料,因為random 不是真正意義上的 隨機數,是偽隨機,random類是乙個產生偽隨機數字的類,它的建構函式有兩種,乙個是直接newrandom 另外乙個是newrandom int32 前者是根據觸發那刻的系統...
js 獲取隨機數的方法
function getrandomnum min,max var num getrandomnum 1,10 alert num 1.math.random 結果為0 1間的乙個隨機數 包括0,不包括1 2.math.floor num 引數num為乙個數值,函式結果為num的整數部分。3.mat...