日期:2014-05-17 浏览次数:20454 次
$query="SELECT * FROM shiti WHERE skemu = " . intval($kemuid) . " order by random() limit 1";
static function getIDs($kemuid)
{
$cachefile="cache/" . $kemuid . ".cache";
$datas=array();
if (!file_exists($cachefile)||time() < (filemtime($cachefile) + 14400))
//缓存不存在或超过4小时
{
global $data;
//读取 id 集
$query="SELECT sid FROM shiti WHERE skemu = " . intval($kemuid);
$res = $data->query($query);
while($r = $data->fetchArray($res))
{
$datas[]=$r['sid'];
}
//写入缓存
file_put_contents($cachefile,serialize($datas));
}
else
{
//读出缓存
$fp = fopen($cachefile,'r');//读
$datas = unserialize(fread($fp,filesize($cachefile)));//反序列化,并赋值
}
return $datas;
}
调用它的读取随机记录函数:static function getRondam($kemuid)
{
global $data;
$ids=self::getIDs($kemuid);
$index=rand(0,count($ids)-1);
$id=$ids[$index];
$query="SELECT * FROM shiti WHERE sid = " . intval($id);
$res = $data->query($query);
$r = $data->fetchArray($res);
$r['da']=$s;
return $r;
}
这样比每次执行随机查询快多了,但是还是要比生成一个HTML缓存要慢一点,但那样需要把更多数据暴露给客户端,或是存储更多缓存,我想这已经是一个比较均衡的方案了。 这个解决办法的要点在于数组的序列化与反序列化,大家应该很容易看得懂。