ここで明らかな何かが欠けているに違いないと思います。Doctrine と Zend Framework を一緒にセットアップしました。プロファイラーを使用するためのDoctrineのドキュメントに基づいて、bootstrap.phpファイルには次のものがあります。
$profiler = new Doctrine_Connection_Profiler();
$conn = Doctrine_Manager::connection();
$conn->setListener($profiler);
(...)
$frontController = Zend_Controller_Front::getInstance();
(...)
$query_count = 0;
$time = 0;
echo "<table width='100%' border='1'>";
foreach ( $profiler as $event ) {
if ($event->getName() != 'execute') {
continue;
}
$query_count++;
echo "<tr>";
$time += $event->getElapsedSecs() ;
echo "<td>" . $event->getName() . "</td><td>" . sprintf ( "%f" , $event->getElapsedSecs() ) . "</td>";
echo "<td>" . $event->getQuery() . "</td>" ;
$params = $event->getParams() ;
if ( ! empty ( $params ) ) {
echo "<td>";
echo join(', ', $params);
echo "</td>";
}
echo "</tr>";
}
echo "</table>";
echo "Total time: " . $time . ", query count: $query_count <br>\n ";
エラーはありません。最後にプロファイラーの出力に「合計時間: 0、クエリ数: 0」のみが出力されます。
クエリが実行されるため、接続は確実に機能しています。Doctrine_Query::create() を使用して一連のアイテムをフェッチする SELECT があり、それが execute メソッドです。