当前位置: 首页>>代码示例>>PHP>>正文


PHP Doctrine_Record::assignIdentifier方法代码示例

本文整理汇总了PHP中Doctrine_Record::assignIdentifier方法的典型用法代码示例。如果您正苦于以下问题:PHP Doctrine_Record::assignIdentifier方法的具体用法?PHP Doctrine_Record::assignIdentifier怎么用?PHP Doctrine_Record::assignIdentifier使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Doctrine_Record的用法示例。


在下文中一共展示了Doctrine_Record::assignIdentifier方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: _assignIdentifier

 protected function _assignIdentifier(Doctrine_Record $record)
 {
     $table = $record->getTable();
     $identifier = $table->getIdentifier();
     $seq = $table->sequenceName;
     if (empty($seq) && !is_array($identifier) && $table->getIdentifierType() != Doctrine_Core::IDENTIFIER_NATURAL) {
         $id = false;
         if ($record->{$identifier} == null) {
             if (($driver = strtolower($this->conn->getDriverName())) == 'pgsql') {
                 $seq = $table->getTableName() . '_' . $table->getColumnName($identifier);
             } elseif ($driver == 'oracle' || $driver == 'mssql') {
                 $seq = $table->getTableName();
             }
             $id = $this->conn->sequence->lastInsertId($seq);
         } else {
             $id = $record->{$identifier};
         }
         if (!$id) {
             throw new Doctrine_Connection_Exception("Couldn't get last insert identifier.");
         }
         $record->assignIdentifier($id);
     } else {
         $record->assignIdentifier(true);
     }
 }
开发者ID:sensorsix,项目名称:app,代码行数:25,代码来源:UnitOfWork.php

示例2: processSingleInsert

 /**
  * @todo DESCRIBE WHAT THIS METHOD DOES, PLEASE!
  */
 public function processSingleInsert(Doctrine_Record $record)
 {
     $fields = $record->getPrepared();
     $table = $record->getTable();
     // Populate fields with a blank array so that a blank records can be inserted
     if (empty($fields)) {
         foreach ($table->getFieldNames() as $field) {
             $fields[$field] = null;
         }
     }
     $identifier = (array) $table->getIdentifier();
     $seq = $record->getTable()->sequenceName;
     if (!empty($seq)) {
         $id = $this->conn->sequence->nextId($seq);
         $seqName = $table->getIdentifier();
         $fields[$seqName] = $id;
         $record->assignIdentifier($id);
     }
     $this->conn->insert($table, $fields);
     if (empty($seq) && count($identifier) == 1 && $identifier[0] == $table->getIdentifier() && $table->getIdentifierType() != Doctrine::IDENTIFIER_NATURAL) {
         if (($driver = strtolower($this->conn->getDriverName())) == 'pgsql') {
             $seq = $table->getTableName() . '_' . $identifier[0];
         } elseif ($driver == 'oracle') {
             $seq = $table->getTableName();
         }
         $id = $this->conn->sequence->lastInsertId($seq);
         if (!$id) {
             throw new Doctrine_Connection_Exception("Couldn't get last insert identifier.");
         }
         $record->assignIdentifier($id);
     } else {
         $record->assignIdentifier(true);
     }
 }
开发者ID:prismhdd,项目名称:victorioussecret,代码行数:37,代码来源:UnitOfWork.php

示例3: insert

 /**
  * inserts a record into database
  *
  * @param Doctrine_Record $record   record to be inserted
  * @return boolean
  */
 public function insert(Doctrine_Record $record)
 {
     // listen the onPreInsert event
     $event = new Doctrine_Event($this, Doctrine_Event::RECORD_INSERT);
     $record->preInsert($event);
     if (!$event->skipOperation) {
         $array = $record->getPrepared();
         if (empty($array)) {
             return false;
         }
         $table = $record->getTable();
         $keys = $table->getPrimaryKeys();
         $seq = $record->getTable()->sequenceName;
         if (!empty($seq)) {
             $id = $this->conn->sequence->nextId($seq);
             $name = $record->getTable()->getIdentifier();
             $array[$name] = $id;
             $record->assignIdentifier($id);
         }
         $this->conn->insert($table->getTableName(), $array);
         if (empty($seq) && count($keys) == 1 && $keys[0] == $table->getIdentifier() && $table->getIdentifierType() != Doctrine::IDENTIFIER_NATURAL) {
             if (strtolower($this->conn->getName()) == 'pgsql') {
                 $seq = $table->getTableName() . '_' . $keys[0];
             }
             $id = $this->conn->sequence->lastInsertId($seq);
             if (!$id) {
                 $id = $table->getMaxIdentifier();
             }
             $record->assignIdentifier($id);
         } else {
             $record->assignIdentifier(true);
         }
     }
     $record->getTable()->addRecord($record);
     $record->postInsert($event);
     return true;
 }
开发者ID:snouhaud,项目名称:camptocamp.org,代码行数:43,代码来源:UnitOfWork.php

示例4: _assignIdentifier

 protected function _assignIdentifier(Doctrine_Record $record)
 {
     $table = $record->getTable();
     $identifier = (array) $table->getIdentifier();
     $seq = $table->sequenceName;
     if (empty($seq) && count($identifier) == 1 && $identifier[0] == $table->getIdentifier() && $table->getIdentifierType() != Doctrine_Core::IDENTIFIER_NATURAL) {
         if (($driver = strtolower($this->conn->getDriverName())) == 'pgsql') {
             $seq = $table->getTableName() . '_' . $identifier[0];
         } elseif ($driver == 'oracle') {
             $seq = $table->getTableName();
         }
         $id = $this->conn->sequence->lastInsertId($seq);
         if (!$id) {
             throw new Doctrine_Connection_Exception("Couldn't get last insert identifier.");
         }
         $record->assignIdentifier($id);
     } else {
         $record->assignIdentifier(true);
     }
 }
开发者ID:arenatournament,项目名称:geek-land,代码行数:20,代码来源:UnitOfWork.php

示例5: processSingleInsert

 /**
  * @todo DESCRIBE WHAT THIS METHOD DOES, PLEASE!
  */
 public function processSingleInsert(Doctrine_Record $record)
 {
     $fields = $record->getPrepared();
     if (empty($fields)) {
         return false;
     }
     $table = $record->getTable();
     $identifier = (array) $table->getIdentifier();
     $seq = $record->getTable()->sequenceName;
     if (!empty($seq)) {
         $id = $this->conn->sequence->nextId($seq);
         $seqName = $table->getIdentifier();
         $fields[$seqName] = $id;
         $record->assignIdentifier($id);
     }
     $this->conn->insert($table, $fields);
     if (empty($seq) && count($identifier) == 1 && $identifier[0] == $table->getIdentifier() && $table->getIdentifierType() != Doctrine::IDENTIFIER_NATURAL) {
         if (strtolower($this->conn->getName()) == 'pgsql') {
             $seq = $table->getTableName() . '_' . $identifier[0];
         }
         $id = $this->conn->sequence->lastInsertId($seq);
         if (!$id) {
             throw new Doctrine_Connection_Exception("Couldn't get last insert identifier.");
         }
         $record->assignIdentifier($id);
     } else {
         $record->assignIdentifier(true);
     }
 }
开发者ID:kirvin,项目名称:the-nerdery,代码行数:32,代码来源:UnitOfWork.php


注:本文中的Doctrine_Record::assignIdentifier方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。