加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > PHP > 正文

cakephp在执行前看到编译的SQL查询

发布时间:2020-05-25 09:45:50 所属栏目:PHP 来源:互联网
导读:我的查询获取每次运行的超时错误.它与联接分页. 我想调试SQL,但由于我得到一个超时,我看不到它. 执行前如何查看编译的SQL查询? 一些蛋糕代码: $this - paginate = array( limit = 16, joins = array( array( table = products,

我的查询获取每次运行的超时错误.它与联接分页.
我想调试SQL,但由于我得到一个超时,我看不到它.

执行前如何查看编译的SQL查询?

一些蛋糕代码:

$this -> paginate = array(
        'limit' => '16','joins' => array( array(
                'table' => 'products','alias' => 'Product','type' => 'LEFT','conditions' => array('ProductModel.id = Product.product_model_id')
            )),'fields' => array(
            'COUNT(Product.product_model_id) as Counter','ProductModel.name'
            ),'conditions' => array(
            'ProductModel.category_id' => $category_id,),'group' => array('ProductModel.id')
    );
首先,在app / config / config.php中将调试变量设置为2.

然后添加:

<?php echo $this->element('sql_dump');?>

在布局的最后.这实际上应该在您的默认蛋糕布局中注释掉.

您现在将可以看到所有进入数据库的SQL查询.

现在复制查询并使用数据库中的SQL EXPLAIN命令(用于MySQL的链接)来查看DBMS中查询的内容.有关CakePHP调试的详细信息,请查阅here.

由于您的脚本甚至不能渲染您可以尝试从数据源直接获取最新的日志:

function getLastQuery()
{
    $dbo = $this->getDatasource();
    $logs = $dbo->getLog();
    $lastLog = end($logs['log']);
    return $lastLog['query'];
}

由于getDatasource()函数在模型中定义,所以需要在模型中.检查整个$logs变量,看看那里有什么.

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读