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


PHP AbstractPlatform::getEmptyIdentityInsertSQL方法代碼示例

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


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

示例1: _getInsertSQL

 /**
  * Gets the INSERT SQL used by the persister to persist a new entity.
  *
  * @return string
  */
 protected function _getInsertSQL()
 {
     if ($this->_insertSql === null) {
         $insertSql = '';
         $columns = $this->_getInsertColumnList();
         if (empty($columns)) {
             $insertSql = $this->_platform->getEmptyIdentityInsertSQL($this->_class->getQuotedTableName($this->_platform), $this->_class->getQuotedColumnName($this->_class->identifier[0], $this->_platform));
         } else {
             $columns = array_unique($columns);
             $values = array_fill(0, count($columns), '?');
             $insertSql = 'INSERT INTO ' . $this->_class->getQuotedTableName($this->_platform) . ' (' . implode(', ', $columns) . ') ' . 'VALUES (' . implode(', ', $values) . ')';
         }
         $this->_insertSql = $insertSql;
     }
     return $this->_insertSql;
 }
開發者ID:manish436,項目名稱:zform,代碼行數:21,代碼來源:BasicEntityPersister.php

示例2: _getInsertSQL

 /**
  * Gets the INSERT SQL used by the persister to persist a new entity.
  *
  * @return string
  */
 protected function _getInsertSQL()
 {
     if ($this->_insertSql === null) {
         $insertSql = '';
         $columns = $this->_getInsertColumnList();
         if (empty($columns)) {
             $insertSql = $this->_platform->getEmptyIdentityInsertSQL($this->_class->getQuotedTableName($this->_platform), $this->_class->getQuotedColumnName($this->_class->identifier[0], $this->_platform));
         } else {
             $columns = array_unique($columns);
             $values = array();
             foreach ($columns as $column) {
                 $placeholder = '?';
                 if (isset($this->_columnTypes[$column]) && isset($this->_class->fieldMappings[$this->_class->fieldNames[$column]]['requireSQLConversion'])) {
                     $type = Type::getType($this->_columnTypes[$column]);
                     $placeholder = $type->convertToDatabaseValueSQL('?', $this->_platform);
                 }
                 $values[] = $placeholder;
             }
             $insertSql = 'INSERT INTO ' . $this->_class->getQuotedTableName($this->_platform) . ' (' . implode(', ', $columns) . ') VALUES (' . implode(', ', $values) . ')';
         }
         $this->_insertSql = $insertSql;
     }
     return $this->_insertSql;
 }
開發者ID:pabloasc,項目名稱:test_social,代碼行數:29,代碼來源:BasicEntityPersister.php

示例3: getInsertSQL

    /**
     * Gets the INSERT SQL used by the persister to persist a new entity.
     *
     * @return string
     */
    protected function getInsertSQL()
    {
        if ($this->insertSql !== null) {
            return $this->insertSql;
        }

        $columns   = $this->getInsertColumnList();
        $tableName = $this->quoteStrategy->getTableName($this->class, $this->platform);

        if (empty($columns)) {
            $identityColumn  = $this->quoteStrategy->getColumnName($this->class->identifier[0], $this->class, $this->platform);
            $this->insertSql = $this->platform->getEmptyIdentityInsertSQL($tableName, $identityColumn);

            return $this->insertSql;
        }

        $values  = array();
        $columns = array_unique($columns);

        foreach ($columns as $column) {
            $placeholder = '?';

            if (isset($this->class->fieldNames[$column]) 
                && isset($this->columnTypes[$this->class->fieldNames[$column]])
                && isset($this->class->fieldMappings[$this->class->fieldNames[$column]]['requireSQLConversion'])) {

                $type        = Type::getType($this->columnTypes[$this->class->fieldNames[$column]]);
                $placeholder = $type->convertToDatabaseValueSQL('?', $this->platform);
            }

            $values[] = $placeholder;
        }

        $columns = implode(', ', $columns);
        $values  = implode(', ', $values);

        $this->insertSql = sprintf('INSERT INTO %s (%s) VALUES (%s)', $tableName, $columns, $values);

        return $this->insertSql;
    }
開發者ID:nattaphat,項目名稱:hgis,代碼行數:45,代碼來源:BasicEntityPersister.php


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