name = $viewName; $this->query = $query; $this->query->setView($this); $this->dbh = $query->getConnection()->getDBH(); } /** * simple get method for getting * the associated query object * * @return Doctrine_Query */ public function getQuery() { return $this->query; } /** * returns the name of this view * * @return string */ public function getName() { return $this->name; } /** * returns the database handler * * @return PDO */ public function getDBH() { return $this->dbh; } /** * creates this view * * @return void */ public function create() { $sql = sprintf(self::CREATE, $this->name, $this->query->getQuery()); try { $this->dbh->query($sql); } catch(Exception $e) { throw new Doctrine_View_Exception($e->__toString()); } } /** * drops this view * * @return void */ public function drop() { try { $this->dbh->query(sprintf(self::DROP, $this->name)); } catch(Exception $e) { throw new Doctrine_View_Exception($e->__toString()); } } /** * executes the view * * @return Doctrine_Collection */ public function execute() { return $this->query->execute(); } /** * @return string */ public function getSelectSql() { return sprintf(self::SELECT, $this->name); } }