Basic Components - Db - Chaining listeners.php 733 Bytes
Newer Older
1 2 3 4
<?php

// using PDO dsn for connecting sqlite memory table

zYne's avatar
zYne committed
5
$dbh = Doctrine_Db::getConnection('sqlite::memory:');
6

zYne's avatar
zYne committed
7
class Counter extends Doctrine_Db_EventListener {
8 9
    private $queries = 0;

zYne's avatar
zYne committed
10
    public function onQuery(Doctrine_Db_Event $event) {
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
        $this->queries++;
    }
    public function count() {
        return count($this->queries);
    }
}
class OutputLogger extends Doctrine_Overloadable {
    public function __call($m, $a) {
        print $m." called!";
    }
}
$counter = new Counter();

$dbh->addListener($counter);
$dbh->addListener(new OutputLogger());

$dbh->query("SELECT * FROM foo"); 
// prints:
// onPreQuery called!
// onQuery called!

print $counter->count(); // 1

?>