“生成本次页面一共花费了xx毫秒,进行了xx次数据库查询”,这个功能是如何实现的呢?
发布网友
发布时间:2022-04-07 21:12
我来回答
共1个回答
热心网友
时间:2022-04-07 22:41
大概说下思路:
1. 在类的构造函数中声明全局变量
定义一个全局变量 $queries 用来统计页面生成经过的数据库查询次数。
function __construct()
{
parent::__construct();
global $queries;
}
2. 修改数据库类中封装好的的 query()
你应该有用到数据库类吧,找到它封装 query() 的方法,比如下面的:
public function query($query)
{
++$GLOBALS['queries'];
return $this->result = mysql_query($query, $this->link);
}
那么每执行一次 Query,全局变量 queries 就会自增1。
3. 在方法体中这样写:
public function content($id = 0)
{
$GLOBALS['queries'] = 0;
echo $GLOBALS['queries'];
}
4.计算PHP脚本执行的函数
public function runtime($mode = 0) {
static $t;
if(!$mode) {
$t = microtime();
return;
}
$t1 = microtime();
//list($m0,$s0) = split(" ",$t);
list($m0,$s0) = explode(" ",$t);
//list($m1,$s1) = split(" ",$t1);
list($m1,$s1) = explode(" ",$t1);
return sprintf("%.3f ms",($s1+$m1-$s0-$m0)*1000);
}
使用如下:
public function content($id = 0)
{
$this -> runtime();
$GLOBALS['queries'] = 0;
echo $GLOBALS['queries'];
echo $this -> runtime(1);
}