欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php 隨機(jī)記錄mysql rand()造成CPU 100%的解決辦法

 更新時(shí)間:2010年05月18日 01:34:30   作者:  
mysql數(shù)據(jù)庫有10幾萬條數(shù)據(jù),使用rand()提取隨機(jī)10條記錄,導(dǎo)致服務(wù)器cpu占用居高不下直至死機(jī)~
百度查閱了一些資料,再結(jié)合自己的一些經(jīng)驗(yàn),采用以下解決辦法:
復(fù)制代碼 代碼如下:

$idlist='';
for($i=1;$i<=20;$i++){
if($i==1){
$idlist=mt_rand(3,25216);
}
else{
$idlist=$idlist.','.mt_rand(3,25216);
}
}
$query="select * from table where id in ($idlist) LIMIT 0,10";

原理其實(shí)很簡單,就是產(chǎn)生一組隨機(jī)ID,然后檢索這一組ID對應(yīng)的記錄,經(jīng)過這樣優(yōu)化,頁面打開速度明顯快了很多,CPU占用率也小到幾乎為0,呵呵~順便用這個(gè)思路把sqlserver站點(diǎn)也優(yōu)化了一下!
速度比較:
用rand()取10條隨機(jī)記錄要400多毫秒,而用上面的方法只要0.6毫秒左右,差別太大了!??!

相關(guān)文章

最新評論