国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

mysql實現(xiàn)隨機查詢經(jīng)驗談

2024-07-24 12:47:57
字體:
供稿:網(wǎng)友

一、隨機查詢一條數(shù)據(jù)

方法一:SELECT * FROM `table` ORDER BY RAND() limit 1

評價:不建議使用,效率非常低,官方文檔中進行說明:Order By和RAND()連用,會多次掃描表,導(dǎo)致速度變慢。

方法二:SELECT * FROM `table`
  WHERE id >= (SELECT floor(RAND() * (SELECT MAX(id) FROM `table`))) 
  ORDER BY id LIMIT 1;

      解釋:SELECT MAX(id) FROM `table` 這句話查詢出最大的id值

               SELECT floor(RAND() * (SELECT MAX(id) FROM `table`)) 這句獲取一個小于MAX(id)的隨機數(shù)

WHERE id >= (SELECT floor(RAND() * (SELECT MAX(id) FROM `table`))) 這句話篩選出所有的大于生成隨機數(shù)的id的行

    然后最后就把大于這個隨機id的行查詢出來,然后按照id排序,選擇第一個,就相當(dāng)與獲取了所有行中隨機的一行。

         評價:有問題,如果id不是從0開始的話,比如從10000開始自增,那么 SELECT floor(RAND() * (SELECT MAX(id) FROM `table`)) 得到的將是會喲很大概率得到小于10000的值,經(jīng)過where限定的查詢結(jié)果將會是所有的查詢結(jié)果的幾率變大,最后limit 1獲取的是第一行數(shù)據(jù)的幾率變高。

方法三:SELECT * FROM `table`
WHERE id >= (SELECT floor( RAND() * ((SELECT MAX(id) FROM `table`)-(SELECT MIN(id) FROM `table`)) + (SELECTMIN(id) FROM `table`)))   ORDER BY id LIMIT 1;

方法四:SELECT *
FROM `table` AS t1 JOIN (SELECT ROUND(RAND() * ((SELECT MAX(id) FROM `table`)-(SELECT MIN(id) FROM `table`))+

(SELECT MIN(id) FROM `table`)) AS id) AS t2
WHERE t1.id >= t2.id
ORDER BY t1.id LIMIT 1;

評價:解決了方法二中MAX(id)的問題,RAND() * ((SELECT MAX(id) FROM `table`)-(SELECT MIN(id) FROM `table`)) + (SELECTMIN(id) FROM `table`)可以獲取MAX(id)和MIN(id)中的隨機數(shù)。

方法四要比方法三稍快一點,//www.survivalescaperooms.com/article/42229.htm 這篇文章指出,15w條數(shù)據(jù)前者花費時間 0.147433 秒,后者花費時間 0.015130 秒。

以上解決方案都默認(rèn)有一個不重復(fù)的數(shù)字字段,其實現(xiàn)在很多表的設(shè)計都是以一個自增段作為主鍵,當(dāng)然還有一些是以uuid作為主鍵的,而沒有數(shù)字鍵,這樣的話,可以用mysql的函數(shù)將uuid的字符串轉(zhuǎn)換成數(shù)字。而且還有一個問題,如果id字段的數(shù)字分布不均勻的話(比如按照1,4,5,6,7,8,45這樣分布),也會造成隨機查詢的不合理,但是這里就不討論那么復(fù)雜的問題了。

二、隨機查詢多條數(shù)據(jù)

方法一:把隨機查詢一條數(shù)據(jù)的limit 1修改成limit 5

評價:這樣獲取的數(shù)據(jù)會是連續(xù)的。

方法二:

SELECT *

FROM `table` AS t1 JOIN (

SELECT ROUND(RAND() * ((SELECT MAX(id) FROM `table`)-(SELECT MIN(id) FROM `table`))+(SELECT MIN(id) FROM `table`)) AS id

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 保亭| 济源市| 新竹市| 张家口市| 中牟县| 西乡县| 麻江县| 广丰县| 江口县| 来安县| 重庆市| 甘肃省| 东城区| 汶上县| 光山县| 贵阳市| 许昌县| 汪清县| 平江县| 方山县| 木里| 高州市| 额尔古纳市| 根河市| 砀山县| 樟树市| 兴安县| 罗甸县| 烟台市| 盐山县| 嘉禾县| 清原| 辽宁省| 漾濞| 台东市| 房产| 黄石市| 枣庄市| 获嘉县| 永丰县| 西华县|