當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Doctrine_Event::getQuery方法代碼示例

本文整理匯總了PHP中Doctrine_Event::getQuery方法的典型用法代碼示例。如果您正苦於以下問題:PHP Doctrine_Event::getQuery方法的具體用法?PHP Doctrine_Event::getQuery怎麽用?PHP Doctrine_Event::getQuery使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Doctrine_Event的用法示例。


在下文中一共展示了Doctrine_Event::getQuery方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: preDqlDelete

 public function preDqlDelete(Doctrine_Event $event)
 {
     $params = $event->getParams();
     $query = $event->getQuery();
     $table = $params['component']['table'];
     $identifier = $table->getIdentifier();
     $tmpQuery = clone $event->getQuery();
     $subQuery = $tmpQuery->select($params['alias'] . '.' . $identifier);
     $records = $subQuery->execute();
     if ($records instanceof Doctrine_Collection && $records->count()) {
         $q = Doctrine::getTable('ActivityData')->createQuery()->where('foreign_table = ?', $table->getTableName())->andWhereIn('foreign_id', array_values($records->toKeyValueArray($identifier, $identifier)))->delete()->execute();
     }
 }
開發者ID:te-koyama,項目名稱:openpne,代碼行數:13,代碼來源:opActivityCascadingListener.class.php

示例2: preDqlDelete

 public function preDqlDelete(Doctrine_Event $event)
 {
     $params = $event->getParams();
     $tmpQuery = clone $event->getQuery();
     $subQuery = $tmpQuery->select($params['alias'] . '.' . $params['component']['table']->getIdentifier())->getDql();
     if (!in_array($params['alias'], $tmpQuery->getDqlPart('from'))) {
         return false;
     }
     $targets = $this->detectCascadingTargets($params['component']['table']);
     foreach ($targets as $target) {
         $table = Doctrine::getTable($target['table']);
         $relation = $table->getRelation($target['aliasFrom']);
         $localField = $relation->getLocalFieldName();
         $q = $table->createQuery();
         $q = $q->where($q->getRootAlias() . '.' . $localField . ' IN (' . $subQuery . ')');
         switch (strtolower($target['delete'])) {
             case 'cascade':
                 $q->delete()->execute();
                 break;
             case 'set null':
                 $q->update()->set($localField, '?', array(null))->execute();
                 break;
             default:
                 // do nothing
         }
     }
 }
開發者ID:phenom,項目名稱:OpenPNE3,代碼行數:27,代碼來源:opApplicationLevelCascadingListener.class.php

示例3: preStmtExecute

 public function preStmtExecute(Doctrine_Event $event)
 {
     // Check if the administrator has enabled the query logging feature
     if (Settings::findbyParam('debug_queries')) {
         $breadcrumps = array();
         $query = $event->getQuery();
         $params = $event->getParams();
         $callers = array_reverse(debug_backtrace(), true);
         $callers = array_slice($callers, 4, count($callers) - 10);
         foreach ($callers as $caller) {
             $class = !empty($caller['class']) ? $caller['class'] : null;
             $breadcrumps[] = $class . "->" . $caller['function'];
         }
         $strBreadcrump = "System: " . implode(" / ", $breadcrumps);
         //the below makes some naive assumptions about the queries being logged
         while (sizeof($params) > 0) {
             $param = array_shift($params);
             if (!is_numeric($param)) {
                 $param = sprintf("'%s'", $param);
             }
             $query = substr_replace($query, $param, strpos($query, '?'), 1);
         }
         Shineisp_Commons_Utilities::log($query, "queries.log");
         Shineisp_Commons_Utilities::log($strBreadcrump, "debug.log", Zend_Log::DEBUG);
         // Increase query counter
         $queryCount = Shineisp_Registry::isRegistered('querycount') ? Shineisp_Registry::get('querycount') : 0;
         $queryCount = $queryCount + 1;
         Shineisp_Registry::set('querycount', $queryCount);
     }
 }
開發者ID:kokkez,項目名稱:shineisp,代碼行數:30,代碼來源:QueriesLogger.php

示例4: preDqlSelect

 /**
  * Adds categories relation specific joins.
  *
  * @param Doctrine_Event $event Event.
  *
  * @return void
  */
 public function preDqlSelect(Doctrine_Event $event)
 {
     $query = $event->getQuery();
     $params = $event->getParams();
     // aliases must be specific to entities
     $aliasCategories = $params['alias'] . 'Catmapobj';
     $dql = $params['alias'] . '.Categories ' . $aliasCategories . ' INDEXBY ' . $aliasCategories . '.reg_property';
     if (!$query->contains($dql)) {
         $query->leftJoin($dql)->leftJoin($aliasCategories . '.Category ' . $params['alias'] . 'Cat');
     }
 }
開發者ID:projectesIF,項目名稱:Sirius,代碼行數:18,代碼來源:Categorisable.php

示例5: preDqlSelect

 public function preDqlSelect(Doctrine_Event $event)
 {
     if (!opActivateBehavior::getEnabled()) {
         return null;
     }
     $params = $event->getParams();
     $field = $params['alias'] . '.is_active';
     $query = $event->getQuery();
     if (!$query->contains($field)) {
         $query->addWhere($field . ' = ? OR ' . $field . ' IS NULL', array(true));
     }
 }
開發者ID:te-koyama,項目名稱:openpne,代碼行數:12,代碼來源:opActivateListener.class.php

示例6: preStmtExecute

 public function preStmtExecute(Doctrine_Event $event)
 {
     $query = $event->getQuery();
     $params = $event->getParams();
     //the below makes some naive assumptions about the queries being logged
     while (sizeof($params) > 0) {
         $param = array_shift($params);
         if (!is_numeric($param)) {
             $param = sprintf("'%s'", $param);
         }
         $query = substr_replace($query, $param, strpos($query, '?'), 1);
         debug($query);
     }
 }
開發者ID:Ryan-Nolan,項目名稱:boxbilling,代碼行數:14,代碼來源:QueryDebuggerListener.php

示例7: preStmtExecute

 /**
  * preStmtExecute
  *
  * @param string $Doctrine_Event
  * @return void
  */
 public function preStmtExecute(Doctrine_Event $event)
 {
     $query = $event->getQuery();
     $params = $event->getParams();
     foreach ($params as $key => $value) {
         if (is_numeric($key)) {
             // it's a '?'
             $query = preg_replace('/\\?/', "'" . $value . "'", $query, 1);
         } else {
             $params[$key] = "'" . $value . "'";
         }
     }
     $this->queries[] = strtr($query, $params);
 }
開發者ID:robinkanters,項目名稱:dnsleergemeenschap,代碼行數:20,代碼來源:sfDoctrineFinderListener.php

示例8: preDqlSelect

 /**
  * (non-PHPdoc)
  * @see branch/vendors/doctrine/Doctrine/Record/Doctrine_Record_Listener#preDqlSelect()
  * add a date constraint to every query before it's executed
  * @param Doctrine_Event $event
  * @return void
  */
 public function preDqlSelect(Doctrine_Event $event)
 {
     $query = $event->getQuery();
     if (get_class($query) == Doctrine_Template_Temporal::QUERY_CLASS_NAME) {
         // is this a Temporal query?
         $query_date = $query->getQueryDate($this->date_format);
         if ($query_date !== false) {
             // false means 'ignore query date'
             $params = $event->getParams();
             $eff_date_field = $params['alias'] . '.' . $this->_options['eff_date'];
             $exp_date_field = $params['alias'] . '.' . $this->_options['exp_date'];
             $query->addWhere($eff_date_field . ' <= ?', $query_date);
             $query->addWhere("({$exp_date_field} IS NULL OR {$exp_date_field} > ?)", $query_date);
         }
     }
 }
開發者ID:JoshuaEstes,項目名稱:sfDoctrineExtraPlugin,代碼行數:23,代碼來源:Temporal.php

示例9: preDqlUpdate

 /**
  * Set the updated field for dql update queries
  *
  * @param Doctrine_Event $evet
  * @return void
  */
 public function preDqlUpdate(Doctrine_Event $event)
 {
     try {
         $guard_user = sfContext::getInstance()->getUser()->getGuardUser();
     } catch (Exception $e) {
         return;
     }
     if (!$this->_options['updated']['disabled']) {
         $params = $event->getParams();
         $updatedName = $event->getInvoker()->getTable()->getFieldName($this->_options['updated']['name']);
         $field = $params['alias'] . '.' . $updatedName;
         $query = $event->getQuery();
         if (!$query->contains($field)) {
             $query->set($field, '?', $guard_user);
         }
     }
 }
開發者ID:kbond,項目名稱:zsUtilPlugin,代碼行數:23,代碼來源:zsUsertraceableListener.class.php

示例10: preDqlSelect

 /**
  * Pre SELECT
  */
 public function preDqlSelect(Doctrine_Event $event)
 {
     $query = $event->getQuery();
     $params = $event->getParams();
     $alias = $params['alias'];
     $limit = $query->getDqlPart('limit');
     $limit = count($limit) ? (int) $limit[0] : 0;
     // Если не указан LIMIT 1
     // Если не указан SELECT
     // Если это не подзапрос
     if (1 != $limit && !$query->getDqlPart('select') && !$query->isSubquery()) {
         $skip = $this->getOption('skip');
         $columns = $event->getInvoker()->getTable()->getColumnNames();
         $columns = array_diff($columns, $skip);
         $select = $alias . '.' . join(', ' . $alias . '.', $columns);
         $query->select($select);
     }
 }
開發者ID:pycmam,項目名稱:myImageUploadPlugin,代碼行數:21,代碼來源:Doctrine_Template_SkipColumns.php

示例11: preStmtExecute

 /**
  * Logs a statement execute on behalf of the statement.
  * 
  * @param Doctrine_Event $event
  */
 public function preStmtExecute(Doctrine_Event $event)
 {
     if ($this->options['logging']) {
         $this->dispatcher->notify(new sfEvent($event->getInvoker(), 'application.log', array(sprintf('execute : %s - (%s)', $event->getQuery(), join(', ', self::fixParams($event->getParams()))))));
     }
     sfTimerManager::getTimer('Database (Doctrine)');
     $args = func_get_args();
     $this->__call(__FUNCTION__, $args);
 }
開發者ID:hunde,項目名稱:bsc,代碼行數:14,代碼來源:sfDoctrineConnectionProfiler.class.php

示例12: preDqlSelect

 /**
  * Implement preDqlSelect() hook and add the deleted flag to all queries for which this model 
  * is being used in.
  *
  * @param Doctrine_Event $event 
  * @return void
  */
 public function preDqlSelect(Doctrine_Event $event)
 {
     $params = $event->getParams();
     $field = $params['alias'] . '.' . $this->_options['name'];
     $query = $event->getQuery();
     // We only need to add the restriction if:
     // 1 - We are in the root query
     // 2 - We are in the subquery and it defines the component with that alias
     if ((!$query->isSubquery() || $query->isSubquery() && $query->contains(' ' . $params['alias'] . ' ')) && !$query->contains($field)) {
         if ($this->_options['type'] == 'timestamp') {
             $query->addPendingJoinCondition($params['alias'], $field . ' IS NULL');
         } else {
             if ($this->_options['type'] == 'boolean') {
                 $query->addPendingJoinCondition($params['alias'], $field . ' = ' . $query->getConnection()->convertBooleans(false));
             }
         }
     }
 }
開發者ID:densem-2013,項目名稱:exikom,代碼行數:25,代碼來源:SoftDelete.php

示例13: preDqlUpdate

 /**
  * Set the updated field for dql update queries
  *
  * @param Doctrine_Event $evet
  * @return void
  */
 public function preDqlUpdate(Doctrine_Event $event)
 {
     if (!$this->_options['updated']['disabled']) {
         $params = $event->getParams();
         $updatedName = $event->getInvoker()->getTable()->getFieldName($this->_options['updated']['name']);
         $field = $params['alias'] . '.' . $updatedName;
         $query = $event->getQuery();
         if (!$query->contains($field)) {
             $query->set($field, '?', $this->getTimestamp('updated', $event->getInvoker()->getTable()->getConnection()));
         }
     }
 }
開發者ID:TeamCodeStudio,項目名稱:fpmoz,代碼行數:18,代碼來源:Timestampable.php

示例14: preDqlSelect

 /**
  * Implement preDqlSelect() hook and add the deleted flag to all queries for which this model 
  * is being used in.
  *
  * @param Doctrine_Event $event 
  * @return void
  */
 public function preDqlSelect(Doctrine_Event $event)
 {
     $params = $event->getParams();
     $field = $params['alias'] . '.' . $this->_options['name'];
     $query = $event->getQuery();
     if (!$query->contains($field)) {
         $query->addWhere($field . ' = 0 OR ' . $field . ' IS NULL');
     }
 }
開發者ID:kmatu,項目名稱:phpcollab3,代碼行數:16,代碼來源:SoftDelete.php

示例15: preExecute

 /**
  * Listens the preExecute event of Doctrine_Connection_Statement
  *
  * adds the issued query to internal query stack
  * and checks if cached element exists
  *
  * @return boolean
  */
 public function preExecute(Doctrine_Event $event)
 {
     $query = $event->getQuery();
     $data = false;
     // only process SELECT statements
     if (strtoupper(substr(ltrim($query), 0, 6)) != 'SELECT') {
         return false;
     }
     $this->add($query, $event->getInvoker()->getDbh()->getName());
     $data = $this->_driver->fetch(md5(serialize(array($query, $event->getParams()))));
     $this->success = $data ? true : false;
     if (!$data) {
         $rand = mt_rand() / mt_getrandmax();
         if ($rand <= $this->_options['savePropability']) {
             $stmt = $event->getInvoker()->getStatement();
             $stmt->execute($event->getParams());
             $data = $stmt->fetchAll(Doctrine::FETCH_ASSOC);
             $this->success = true;
             $this->_driver->save(md5(serialize(array($query, $event->getParams()))), $data);
         }
     }
     if ($this->success) {
         $this->_data = $data;
         return true;
     }
     return false;
 }
開發者ID:yasirgit,項目名稱:afids,代碼行數:35,代碼來源:Cache.php


注:本文中的Doctrine_Event::getQuery方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。