phalcon:跟踪sql语句

在phalcon里有一个\Phalcon\Db\Profiler 类,这个类可以用来记录sql语句并计算消耗的时间。那么如何使用它呢?

手册里其实已经提供了方法,总结如下:

1.向$di里注册profiler服务

$di->set(‘profiler‘, function(){
    return new\Phalcon\Db\Profiler();
}, true);

2.注册db服务时,顺便注册下事件

$di->set(‘db‘, function() use ($di) {
    //新建一个事件管理器
    $eventsManager = new \Phalcon\Events\Manager();

    //从di中获取共享的profiler实例
    $profiler = $di->getProfiler();

    //监听所有的db事件
    $eventsManager->attach(‘db‘, function($event, $connection) use ($profiler) {
        //一条语句查询之前事件,profiler开始记录sql语句
        if ($event->getType() == ‘beforeQuery‘) {
            $profiler->startProfile($connection->getSQLStatement());
        }
        //一条语句查询结束,结束本次记录,记录结果会保存在profiler对象中
        if ($event->getType() == ‘afterQuery‘) {
            $profiler->stopProfile();
        }
    });

    $connection = new \Phalcon\Db\Adapter\Pdo\Mysql(array(
        "host" => "localhost",
        "username" => "root",
        "password" => "secret",
        "dbname" => "invo"
    ));

    //将事件管理器绑定到db实例中
    $connection->setEventsManager($eventsManager);

    return $connection;
}); 

3.程序中调出sql记录

//执行一些查询
Robots::find();
Robots::find(array("order" => "name"));
Robots::find(array("limit" => 30));

//获取所有的prifler记录结果,这是一个数组,每条记录对应一个sql语句
$profiles = $this->di->get(‘profiler‘)->getProfiles();
//遍历输出
foreach ($profiles as $profile) {
   echo "SQL语句: ", $profile->getSQLStatement(), "\n";
   echo "开始时间: ", $profile->getInitialTime(), "\n";
   echo "结束时间: ", $profile->getFinalTime(), "\n";
   echo "消耗时间: ", $profile->getTotalElapsedSeconds(), "\n";
}

//直接获取最后一条sql语句
echo $this->di->get(‘profiler‘)->getLastProfile()->getSQLStatement();
时间: 2024-10-25 20:13:14

phalcon:跟踪sql语句的相关文章

通过SQL Server的扩展事件来跟踪SQL语句在运行时,时间都消耗到哪儿了?

原文:通过SQL Server的扩展事件来跟踪SQL语句在运行时,时间都消耗到哪儿了? 问题就是,一个很简单的语句,在不同的服务器上执行,所需要的时间相差很大,特别提到在性能差的服务器上反而快,在性能好的服务器上反而慢,他想知道这是为什么? 对这个问题,我的回答是: 从表面看,很难分析出为什么多台机器执行同一个简单的sql语句,速度有差异,甚至好的服务器反而花了更多的时间,而看上去相对较差的机器反而更快,这些都是表面现象. 我们可以分析一下整个SQL语句执行的大致过程: 1.语句发送到SQL S

mongodb 跟踪SQL语句及慢查询收集

有个需求:跟踪mongodb的SQL语句及慢查询收集 第一步:通过mongodb自带函数可以查看在一段时间内DML语句的运行次数. 在bin目录下面运行  ./mongostat -port 端口号  则可以看到下面的数据 它的输出有以下几列: inserts/s 每秒插入次数 query/s 每秒查询次数 update/s 每秒更新次数 delete/s 每秒删除次数 getmore/s 每秒执行getmore次数 command/s 每秒的命令数,比以上插入.查找.更新.删除的综合还多,还统

Mybatis3中用log4j跟踪SQL语句

在开发过程中,打印SQL语句应该是一个非常有用的功能. 下面介绍如何在Mybatis3中开启打印SQL语句的功能. Mybatis内置的日志工厂提供日志功能,具体的日志实现有以下几种方式: SLF4J Apache Commons Logging Log4j 2 Log4j JDK logging 具体选择哪个日志实现由MyBatis的内置日志工厂确定.它会使用最先找到的(按上文列举的顺序查找). 如果一个都未找到,日志功能就会被禁用 另外Mybatis官网上说Many environments

oracle跟踪sql语句

select * from v$sql 查询客户端电脑名称的ID select terminal, SID,SERIAL#  from v$session where  (terminal) like '%4S%'; alter session set sql_trace=true; alter system set sql_trace=true 跟踪生成的文件在 D:\app\Administrator\diag\rdbms\orcl\orcl\trace 在sqlplus中执行show pa

mysql5.6.16下跟踪SQL查询转换的结果

当SQL执行时,会做一些查询转换,你看到的SQL很可能被转换为其他的形式的SQL执行(有视图重写,查询转换,谓词推进等).在Oracle下,可以通过10053跟踪SQL语句.在mysql下,可以通过设置optimizer_trace来实现. mysql> select version(); +-----------+ | version() | +-----------+ | 5.6.16    | +-----------+ 1 row in set (0.00 sec) mysql> cr

SQL Server扩展事件(Extended Events)-- 使用扩展事件跟踪查询语句

SQL Server扩展事件(Extended Events)-- 使用扩展事件跟踪查询语句 创建扩展事件会话 展开"Object Explorer"."Management"."Extended Events"."Sessions"目录,你会发现一到两个预设的会话.默认,在SQL Server 2012包含system_health会话,而根据不同的SQL Server2012的版本,可能有AlwaysOn_health会话

跟踪oracle中sql语句执行过程及相关知识拓展

<pre name="code" class="sql">select * from v$sqlarea; select * from v$sqlarea where first_load_time>'2010-11-27/09:30:00'; 这个方法查询结果每条记录显示一条查询语句,且只能查询sql_text小于1000字符的,多余的会被截断. 改进一下: select * from v$sqlarea where first_load_tim

oracle sql语句跟踪及性能分析工具实现

在网上找了一大圈,没找着合适的工具来跟踪oracle一段时间的sql. 我们的场景是打算自动化跑遍所有场景(rft)+fiddler跟踪请求+后端跟踪sql,根据结果去分析慢的请求和sql,本来awr报告也能实现,但是每次都用awr比较麻烦,想的是能够简单点,直接定位到执行慢的sql或者耗cpu的sql. 这个工具抓取的sql不是实时的,是某段时间的sql,原理也很简单,比awr的sql要简单的多,试了一把,跟awr给出的数据是一致的. 最终效果:准备操作时开启跟踪,结束操作后关闭跟踪,然后工具

【转】mysql如何跟踪执行的sql语句

转自http://blog.csdn.net/testcs_dn/article/details/18791815 在SQL SERVER下跟踪sql采用事件探查器,而在mysql下如何跟踪sql呢? 其实方法很简单,开启mysql的日志log功能,通过查看跟踪日志即可. 开启mysql的日志log方法: windows环境下的配置方法: 我使用的版本:Version: 5.0.37-community-nt-log (MySQL Community Edition (GPL)) 找到my.in