php 随机记录mysql rand()造成CPU 100%的解决办法
php 随机记录mysql rand()造成CPU 100%的解决办法
发布时间:2016-12-29 来源:查字典编辑
摘要:百度查阅了一些资料,再结合自己的一些经验,采用以下解决办法:复制代码代码如下:$idlist='';for($i=1;$i

百度查阅了一些资料,再结合自己的一些经验,采用以下解决办法:

复制代码 代码如下:

$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";

原理其实很简单,就是产生一组随机ID,然后检索这一组ID对应的记录,经过这样优化,页面打开速度明显快了很多,CPU占用率也小到几乎为0,呵呵~顺便用这个思路把sqlserver站点也优化了一下!

速度比较:

用rand()取10条随机记录要400多毫秒,而用上面的方法只要0.6毫秒左右,差别太大了!!!

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新php教程学习
热门php教程学习
编程开发子分类