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


    很多博客软件都有这么一个功能,比如“生成本次页面一共花费了xx毫秒,进行了xx次数据库查询”等等。那么这个功能是如何实现的呢,下面我大概说下思路。
    
    1. 在类的构造函数中声明全局变量
    
    定义一个全局变量 $queries 用来统计页面生成经过的数据库查询次数。
    1    function __construct()
    2    {
    3        parent::__construct();
    4        global $queries;
    5    }
    
    2. 修改数据库类中封装好的的 query()
    
    你应该有用到数据库类吧,找到它封装 query() 的方法,比如下面的:
    1    // 执行SQL语句
    2    public function query($query)
    3    {
    4        //echo $query.'<br />';
    5        ++$GLOBALS['queries'];
    6        return $this->result = mysql_query($query, $this->link);
    7    }
    
    那么每执行一次 Query,全局变量 queries 就会自增1。
    
    3. 在方法体中这样写:
    1    public function content($id = 0)
    2    {
    3        $GLOBALS['queries'] = 0;
    4        // something to do
    5        echo $GLOBALS['queries'];
    6    }
    
    就这么简单就能实现那个功能了。
    
    4. 附带计算PHP脚本执行的函数
    
    之前写的博文介绍了下计算PHP脚本执行时间的函数,这里再贴一下吧。
    01    // 计时函数
    02    public function runtime($mode = 0) {
    03        static $t;
    04        if(!$mode) {
    05            $t = microtime();
    06            return;
    07        }
    08        $t1 = microtime();
    09        //list($m0,$s0) = split(" ",$t);
    10        list($m0,$s0) = explode(" ",$t);
    11        //list($m1,$s1) = split(" ",$t1);
    12        list($m1,$s1) = explode(" ",$t1);
    13        return sprintf("%.3f ms",($s1+$m1-$s0-$m0)*1000);
    14    }
    
    使用如下:
    view source
    print?
    1    public function content($id = 0)
    2    {
    3        $this -> runtime();
    4        $GLOBALS['queries'] = 0;
    5        // something to do
    6        echo $GLOBALS['queries'];
    7        echo $this -> runtime(1);
    8    }
  • 相关阅读:
    浏览器驱动
    django中的cookie和session
    django自定义中间件实现登陆
    django虚拟环境与文件上传
    了解和熟悉数据库相关知识
    JMeter ---相关脚本笔记
    JMeter脚本---关于时间戳的处理笔记
    JMeter中的读取json数据---JSON Extractor插件
    更多API知识学习
    认识VIM编辑器
  • 原文地址:https://www.cnblogs.com/afei-happy/p/3376049.html
Copyright © 2020-2023  润新知