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),采用以下解決辦法:
$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í)很簡(jiǎn)單,就是產(chǎn)生一組隨機(jī)ID,然后檢索這一組ID對(duì)應(yīng)的記錄,經(jīng)過這樣優(yōu)化,頁面打開速度明顯快了很多,CPU占用率也小到幾乎為0,呵呵~順便用這個(gè)思路把sqlserver站點(diǎn)也優(yōu)化了一下!
速度比較:
用rand()取10條隨機(jī)記錄要400多毫秒,而用上面的方法只要0.6毫秒左右,差別太大了?。?!
復(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í)很簡(jiǎn)單,就是產(chǎn)生一組隨機(jī)ID,然后檢索這一組ID對(duì)應(yīng)的記錄,經(jīng)過這樣優(yōu)化,頁面打開速度明顯快了很多,CPU占用率也小到幾乎為0,呵呵~順便用這個(gè)思路把sqlserver站點(diǎn)也優(yōu)化了一下!
速度比較:
用rand()取10條隨機(jī)記錄要400多毫秒,而用上面的方法只要0.6毫秒左右,差別太大了?。?!
您可能感興趣的文章:
- MySQL的指定范圍隨機(jī)數(shù)函數(shù)rand()的使用技巧
- mysql 某字段插入隨機(jī)數(shù)(插入隨機(jī)數(shù)到MySQL數(shù)據(jù)庫)
- MySQL查詢隨機(jī)數(shù)據(jù)的4種方法和性能對(duì)比
- mysql獲取隨機(jī)數(shù)據(jù)的方法
- mysql優(yōu)化取隨機(jī)數(shù)據(jù)慢的方法
- MySQL取出隨機(jī)數(shù)據(jù)
- 從MySQL數(shù)據(jù)庫表中取出隨機(jī)數(shù)據(jù)的代碼
- MySQL中的RAND()函數(shù)使用詳解
- MySQL下的RAND()優(yōu)化案例分析
- MySQL優(yōu)化之對(duì)RAND()的優(yōu)化方法
- MySQL Order By Rand()效率分析
- mysql中RAND()隨便查詢記錄效率問題和解決辦法分享
- MYSQL隨機(jī)抽取查詢 MySQL Order By Rand()效率問題
- MySQL rand函數(shù)實(shí)現(xiàn)隨機(jī)數(shù)的方法
- PHP mt_rand() 函數(shù)
相關(guān)文章
淺析php面向?qū)ο髉ublic private protected 訪問修飾符
本篇文章是對(duì)php面向?qū)ο髉ublic private protected 訪問修飾符進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
PHP截?cái)鄻?biāo)題且兼容utf8和gb2312編碼
PHP截?cái)鄻?biāo)題的方法有很多,但同時(shí)可以兼容utf8和gb2312卻不多了,下面有個(gè)不錯(cuò)的方法,可以參考下,或許對(duì)大家有所幫助2013-09-09
解析阿里云ubuntu12.04環(huán)境下配置Apache+PHP+PHPmyadmin+MYsql
本篇文章是對(duì)在阿里云ubuntu12.04環(huán)境下配置Apache+PHP+PHPmyadmin+MYsql的具體操作流程進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06

