Chinaunix首页 | 论坛 | 博客
  • 博客访问: 5120113
  • 博文数量: 921
  • 博客积分: 16037
  • 博客等级: 上将
  • 技术积分: 8469
  • 用 户 组: 普通用户
  • 注册时间: 2006-04-05 02:08
文章分类

全部博文(921)

文章存档

2020年(1)

2019年(3)

2018年(3)

2017年(6)

2016年(47)

2015年(72)

2014年(25)

2013年(72)

2012年(125)

2011年(182)

2010年(42)

2009年(14)

2008年(85)

2007年(89)

2006年(155)

分类:

2010-06-12 10:30:51

在本例中,通过时间触发缓存技术被运用,设定一段时间后让其缓存SQL输出过期。在此特殊的例子中,定一段时间为24小时。

序列化例子:

l        连接数据库

l        执行查询

l        取得所有结果构成一个数组以便后面你可以访问

l        序列化数组

l        保存序列化过的数组到文件中

 

<?php
$file = 'sql_cache.txt';

$link = mysql_connect('localhost','username','password')

    or die (mysql_error());

mysql_select_db('shop')

    or die (mysql_error());

/* 构造SQL查询 */

$query = "SELECT * FROM categories";

$result = mysql_query($query)

    or die (mysql_error());

while ($record = mysql_fetch_array($result) )

{

    $records[] = $record;

}

$OUTPUT = serialize($records);

$fp = fopen($file,"w"); // 以写权限的方式打开文件


fputs($fp, $OUTPUT);

fclose($fp);

 

查看sql_cache.txt文件,里面的内容可能类似这样的:

a:1:{i:0;a:6:{i:0;s:1:"1";s:11:"category_id";s:1:"1";i:1;s:9:"Computers";s:13:"category_name";s:9:

"Computers" ;i:2;s:25:"Description for computers";s:20:"category_description"

;s:25:"Description for computers";}}

这个输出是它的变量和类型的内部表现形式。假若你用mysql_fetch_array()函数返回数字索引的数组和一个关联的数组(这就是为什么数据看起来像是发生了两次),一个是数字索引,另一个是字符串索引。

使用缓存:

要用缓存,你需要用函数unserialize()来使数据还原成原始格式与类型。

你可以用file_get_contents()这个函数来读取sql_cache.txt文件的内容,把它赋给一个变量。

请注意:这个函数在PHP4.3.0及以上版本有效。若你使用的是一个老版本的PHP,一个简单的方法是用file()函数(读整个文件到一个数组,每行变成一个数组)implode()函数用于把数组的各元素连接成一个字符串然后使用unserialize()反序列化。


 

<?php
// file_get_contents() 适合于for PHP < 4.3.0


$file = 'sql_cache.txt';

$records = unserialize(implode('',file($file)));

现在你可以通过$records数组并且取得原始查询的数据:

foreach ($records as $id=>$row) {

    print $row['category_name']."
"
;

}


注意$records是数组(一个包含了查询结果的数字索引列——每行是一个数字和一个字符串...真是混乱)的一排。

把它们放在一块:

基于本例子中的时间来决定是否缓存。如果文件修改的时间戳比当前时间戳减去过期时间戳大,那么就用缓存,否则更新缓存。

l        检查文件是否存在并且时间戳小于设置的过期时间

l        获取存储在缓存文件中的记录或者更新缓存文件

 

<?php
$file = 'sql_cache.txt';

$expire = 86400; // 24 小时 (单位:秒)


if (file_exists($file) &&

filemtime($file) > (time() - $expire))

{

    // 取得缓存中的记录


    $records = unserialize(file_get_contents($file));

} else {

    // 通过 serialize() 函数创建缓存


}


附加其它可能的:

l        把缓存结果存储在共享内存中以获取更快的速度

l        增加一个功能随机地运行SQL查询并且检查是否输出与缓存输出一致。如果不一致,则更新缓存(本函数运行次数的概率可以定为1/100)。通过哈希算法(如MD5())可以协助判断字符串或者文件是否改变。

l        增加一个管理员的功能,人工的删除这个缓存文件,以强制更新缓存(如file_exists()函数返回false时)。你可以用函数unlink()删除文件。

脚本:

 

<?php
$file = 'sql_cache.txt';

$expire = 86400; // 24 小时


if (file_exists($file) &&

    filemtime($file) > (time() - $expire)) {

    $records = unserialize(file_get_contents($file));

} else {

    $link = mysql_connect('localhost','username','password')

        or die (mysql_error());

    mysql_select_db('shop')

        or die (mysql_error());

    /* 构造SQL查询 */

    $query = "SELECT * FROM categories";

    $result = mysql_query($query)

        or die (mysql_error());

    while ($record = mysql_fetch_array($result) ) {

        $records[] = $record;

    }

    $OUTPUT = serialize($records);

    $fp = fopen($file,"w");

    fputs($fp, $OUTPUT);

    fclose($fp);

} // end else


 

// 查询结果在数组 $records 中


foreach ($records as $id=>$row) {

    if ($row['category_id'] == $_REQUEST['category_id']) {

        // 被选择的目录显示粗体字


        print ''.$row['category_name'].'
'
;

    } else {

        // 其它目录显示用常规字体


        print $row['category_name'].'
'
;

    }

}


阅读(1231) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~