0

我已经在我的开发站点中设置并打开了 zend 数据库分析器。我可以看到除 DESCRIBE 查询之外的所有查询,我知道它应该在我每次请求新表对象时运行。我正在使用这样的东西来查看查询:

$db = Zend_Registry::get('db');
$profiler = new Zend_Db_Profiler();
$profiler->setEnabled(true);
$db->setProfiler($profiler);

$i = 1;
$output = 'PROFILE FOR: '.$_SERVER['REQUEST_URI'] . "\n";

    foreach ($profiler->getQueryProfiles() as $query) {
        $output .= "Query ".$i++.": ".$query->getQuery(). "\n";
    }
    $output .= 'Average query length: ' . $totalTime / $queryCount .
                ' seconds' . "\n";

    $output .= 'Queries per second: ' . $queryCount / $totalTime . "\n";
    $output .= 'Longest query length: ' . $longestTime . "\n";
    $output .= "Longest query: \n" . $longestQuery . "\n\n";

    file_put_contents('/tmp/zend_profiler.log', $output, FILE_APPEND);
}

不知道为什么我看不到描述查询。有没有其他人遇到过这个问题?

4

1 回答 1

0

也许您已经为您的数据库连接激活了元数据缓存(这通常是一件非常好的事情,尤其是在生产中)。在这种情况下,DESCRIBE在缓存过期之前不会执行查询。

通过在引导后在应用程序中的某处执行此行来验证它

if (null != Zend_Db_Table_Abstract::getDefaultMetadataCache()) {
  echo "Cache is active, describe queries not run";
} else {
  echo "Cache is not active";
}
于 2011-08-22T12:34:47.913 回答