• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

PHP 资料缓存数组的实现

php 搞代码 3年前 (2022-01-26) 35次浏览 已收录 0个评论

PHP 文件缓存数组的实现

在一个试验性项目中,我需要从 sqlite3 数据库中随机读取一条记录给用户,要读取的数据表现在有23850条记录,按 skemu 分类,一般每个 skemu 下有 3000多条记录,原先我使用了 sqlite3 的随机查询语句:

$query="SELECT * FROM shiti WHERE skemu = " . intval($kemuid) . " order by random() limit 1";

然后在我现在用的电脑上没有感觉到明显迟延,但当我把服务器换到一个 P4 1.8G 512M内存的机器上运行时,感觉数据读取速度非常慢,需要2、3秒才能读出数据。如果每次用户要取一条随机记录,都执行这样一个随机查询的话,瓶颈将会出现在数据库查询过程中,难以想像这样的性能如何来适应众多用户的同时访问。为此,我考虑减少数据库的查询次数,先把记录 9来源gaodai#ma#com搞@代~码$网搞gaodaima代码id 取出来放到数组中,然后从中再来随机取一条记录,同时存为文件供以后读取,这样以减少数据库查询的次数。

以下函数实现读出 id 集:

 static function getIDs($kemuid) {  $cachefile="cache/" . $kemuid . ".cache";  $datas=array();  if (!file_exists($cachefile)||time() 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缓存要慢一点,但那样需要把更多数据暴露给客户端,或是存储更多缓存,我想这已经是一个比较均衡的方案了。

这个解决办法的要点在于数组的序列化与反序列化,大家应该很容易看得懂。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:PHP 资料缓存数组的实现

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址