Rumah > php教程 > php手册 > teks badan

PHP获取生成一个页面的数据库查询次数

WBOY
Lepaskan: 2016-06-13 09:39:17
asal
987 orang telah melayarinya

很多博客软件都有这么一个功能,比如“生成本次页面一共花费了xx毫秒,进行了xx次数据库查询”等等。那么这个功能是如何实现的呢,下面我大概说下思路。

1. 在类的构造函数中声明全局变量

定义一个全局变量 $queries 用来统计页面生成经过的数据库查询次数。

function __construct()
{
	parent::__construct();
	global $queries;
}
Salin selepas log masuk

2. 修改数据库类中封装好的的 query()

你应该有用到数据库类吧,找到它封装 query() 的方法,比如下面的:

// 执行SQL语句
public function query($query)
{
	//echo $query.'<br />';
	++$GLOBALS['queries'];
	return $this->result = mysql_query($query, $this->link);
}
Salin selepas log masuk

那么每执行一次 Query,全局变量 queries 就会自增1。

3. 在方法体中这样写:

public function content($id = 0)
{
	$GLOBALS['queries'] = 0;
	// something to do
	echo $GLOBALS['queries'];
}
Salin selepas log masuk

就这么简单就能实现那个功能了。

4. 附带计算PHP脚本执行的函数

之前写的博文介绍了下计算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); 
} 
Salin selepas log masuk

使用如下:

public function content($id = 0)
{
	$this -> runtime();
	$GLOBALS['queries'] = 0;
	// something to do
	echo $GLOBALS['queries'];
	echo $this -> runtime(1);
}
Salin selepas log masuk
Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Cadangan popular
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!