第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如何在SQL中請(qǐng)求隨機(jī)行?

如何在SQL中請(qǐng)求隨機(jī)行?

神不在的星期二 2019-06-03 10:29:21
如何在SQL中請(qǐng)求隨機(jī)行?如何在純SQL中請(qǐng)求隨機(jī)行(或盡可能接近真正的隨機(jī)行)?
查看完整描述

4 回答

?
汪汪一只貓

TA貢獻(xiàn)1898條經(jīng)驗(yàn) 獲得超8個(gè)贊

像杰里米這樣的解決方案:

SELECT * FROM table ORDER BY RAND() LIMIT 1

工作,但它們需要對(duì)所有表進(jìn)行順序掃描(因?yàn)樾枰?jì)算與每一行相關(guān)聯(lián)的隨機(jī)值-以便可以確定最小的值),這對(duì)于即使是中等大小的表也是相當(dāng)慢的。我的建議是使用某種類型的索引數(shù)字列(許多表都將這些列作為主鍵),然后編寫如下內(nèi)容:

SELECT * FROM table WHERE num_value >= RAND() * 
    ( SELECT MAX (num_value ) FROM table ) ORDER BY num_value LIMIT 1

這在對(duì)數(shù)時(shí)間內(nèi)工作,不管表大小如何,如果num_value被索引了。請(qǐng)注意:這假設(shè)num_value平均分布在范圍內(nèi)。0..MAX(num_value)..如果您的數(shù)據(jù)集與此假設(shè)有很大的偏差,您將得到扭曲的結(jié)果(某些行會(huì)比其他行更頻繁地出現(xiàn))。


查看完整回答
反對(duì) 回復(fù) 2019-06-03
?
12345678_0001

TA貢獻(xiàn)1802條經(jīng)驗(yàn) 獲得超5個(gè)贊

ORDER BY NEWID()

取走7.4 milliseconds

WHERE num_value >= RAND() * (SELECT MAX(num_value) FROM table)

取走0.0065 milliseconds!

我肯定會(huì)采用后一種方法。


查看完整回答
反對(duì) 回復(fù) 2019-06-03
  • 4 回答
  • 0 關(guān)注
  • 611 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)