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


PHP AbstractPlatform::appendLockHint方法代碼示例

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


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

示例1: lock

 /**
  * Lock all rows of this entity matching the given criteria with the specified pessimistic lock mode
  *
  * @param array $criteria
  * @param int $lockMode
  * @return void
  */
 public function lock(array $criteria, $lockMode)
 {
     $conditionSql = $this->_getSelectConditionSQL($criteria);
     if ($lockMode == LockMode::PESSIMISTIC_READ) {
         $lockSql = $this->_platform->getReadLockSql();
     } else {
         if ($lockMode == LockMode::PESSIMISTIC_WRITE) {
             $lockSql = $this->_platform->getWriteLockSql();
         }
     }
     $sql = 'SELECT 1 ' . $this->_platform->appendLockHint($this->getLockTablesSql(), $lockMode) . ($conditionSql ? ' WHERE ' . $conditionSql : '') . ' ' . $lockSql;
     list($params, $types) = $this->expandParameters($criteria);
     $stmt = $this->_conn->executeQuery($sql, $params, $types);
 }
開發者ID:manish436,項目名稱:zform,代碼行數:21,代碼來源:BasicEntityPersister.php

示例2: walkSubselectFromClause

 /**
  * {@inheritdoc}
  */
 public function walkSubselectFromClause($subselectFromClause)
 {
     $identificationVarDecls = $subselectFromClause->identificationVariableDeclarations;
     $sqlParts = array();
     foreach ($identificationVarDecls as $subselectIdVarDecl) {
         $sql = $this->walkRangeVariableDeclaration($subselectIdVarDecl->rangeVariableDeclaration);
         foreach ($subselectIdVarDecl->joins as $join) {
             $sql .= $this->walkJoin($join);
         }
         $sqlParts[] = $this->platform->appendLockHint($sql, $this->query->getHint(Query::HINT_LOCK_MODE));
     }
     return ' FROM ' . implode(', ', $sqlParts);
 }
開發者ID:nemekzg,項目名稱:doctrine2,代碼行數:16,代碼來源:SqlWalker.php

示例3: lock

    /**
     * Locks all rows of this entity matching the given criteria with the specified pessimistic lock mode.
     *
     * @param array $criteria
     * @param int   $lockMode
     *
     * @return void
     */
    public function lock(array $criteria, $lockMode)
    {
        $lockSql      = '';
        $conditionSql = $this->getSelectConditionSQL($criteria);

        switch ($lockMode) {
            case LockMode::PESSIMISTIC_READ:
                $lockSql = $this->platform->getReadLockSql();

                break;
            case LockMode::PESSIMISTIC_WRITE:

                $lockSql = $this->platform->getWriteLockSql();
                break;
        }

        $lock  = $this->platform->appendLockHint($this->getLockTablesSql(), $lockMode);
        $where = ($conditionSql ? ' WHERE ' . $conditionSql : '') . ' ';
        $sql = 'SELECT 1 '
             . $lock
             . $where
             . $lockSql;

        list($params, $types) = $this->expandParameters($criteria);

        $this->conn->executeQuery($sql, $params, $types);
    }
開發者ID:nattaphat,項目名稱:hgis,代碼行數:35,代碼來源:BasicEntityPersister.php

示例4: getLockTablesSql

 /**
  * Gets the FROM and optionally JOIN conditions to lock the entity managed by this persister.
  *
  * @param integer $lockMode One of the Doctrine\DBAL\LockMode::* constants.
  *
  * @return string
  */
 protected function getLockTablesSql($lockMode)
 {
     return $this->platform->appendLockHint('FROM ' . $this->quoteStrategy->getTableName($this->class, $this->platform) . ' ' . $this->getSQLTableAlias($this->class->name), $lockMode);
 }
開發者ID:BusinessCookies,項目名稱:CoffeeMachineProject,代碼行數:11,代碼來源:BasicEntityPersister.php

示例5: walkRangeVariableDeclaration

 /**
  * Walks down a RangeVariableDeclaration AST node, thereby generating the appropriate SQL.
  *
  * @param AST\RangeVariableDeclaration $rangeVariableDeclaration
  *
  * @return string
  */
 public function walkRangeVariableDeclaration($rangeVariableDeclaration)
 {
     $class = $this->em->getClassMetadata($rangeVariableDeclaration->abstractSchemaName);
     $dqlAlias = $rangeVariableDeclaration->aliasIdentificationVariable;
     if ($rangeVariableDeclaration->isRoot) {
         $this->rootAliases[] = $dqlAlias;
     }
     $sql = $this->platform->appendLockHint($this->quoteStrategy->getTableName($class, $this->platform) . ' ' . $this->getSQLTableAlias($class->getTableName(), $dqlAlias), $this->query->getHint(Query::HINT_LOCK_MODE));
     if ($class->isInheritanceTypeJoined()) {
         $sql .= $this->_generateClassTableInheritanceJoins($class, $dqlAlias);
     }
     return $sql;
 }
開發者ID:BozzaCoon,項目名稱:SPHERE-Framework,代碼行數:20,代碼來源:SqlWalker.php


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