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


PHP Table::connection方法代碼示例

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


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

示例1: moveNode

 /**
  * Move a node under the same parent node or under a new node.
  * New position of the node can be specified
  *
  * @param int $id ID of the node to move
  * @param int $parent_id ID of the (new) parent node
  * @param int $position New position of the node. Position is zero based.
  * @return boolean
  */
 public function moveNode($id, $parent_id, $position = null)
 {
     $primaryKey = $this->_table->schema()->primaryKey();
     $primaryKey = count($primaryKey) == 1 ? $primaryKey[0] : $primaryKey;
     $parent_id_fieldname = $this->config('model_parent_id_fieldname');
     $sort_fieldname = $this->config('model_sort_fieldname');
     $connection = $this->_table->connection();
     $connection->begin();
     $result = true;
     /*
      * Get moved node
      */
     $node = $this->_table->get($id);
     /*
      * Get current nodes positions of (new) siblings
      */
     $current_children = $this->_table->query()->where([$parent_id_fieldname => $parent_id])->order([$sort_fieldname => 'asc']);
     $new_sort_children = [];
     foreach ($current_children as $current_position => $current_child) {
         if ($current_child->{$primaryKey} != $id) {
             $new_sort_children[] = $current_child;
         }
     }
     /*
      * Default position is after all siblings
      */
     $position = isset($position) ? $position : $current_children->count();
     $position = $position >= 0 ? $position : 0;
     $position = $position <= count($new_sort_children) ? $position : count($new_sort_children);
     /*
      * Insert moved node at position
      */
     array_splice($new_sort_children, $position, 0, array($node));
     /*
      * If node has a new parent -> save it
      */
     if ($node->{$parent_id_fieldname} != $parent_id) {
         $query = $this->_table->query()->update()->set([$parent_id_fieldname => $parent_id])->where([$primaryKey => $id]);
         if (!$query->execute()) {
             $result = false;
         }
     }
     /*
      * Update positions
      */
     foreach ($new_sort_children as $index => $new_sort_child) {
         $query = $this->_table->query()->update()->set([$sort_fieldname => $index * 10])->where([$primaryKey => $new_sort_child->{$primaryKey}]);
         if (!$query->execute()) {
             $result = false;
         }
     }
     /***********/
     if ($result) {
         $connection->commit();
     } else {
         $connection->rollback();
     }
     return $result;
 }
開發者ID:alaxos,項目名稱:cakephp3-libs,代碼行數:68,代碼來源:AncestorBehavior.php

示例2: truncateTable

 /**
  * Helper method that clears all records from the provided Table instance.
  *
  * The default file is `config/seed.php`. When the `--dev` flag is
  * present, the default file changes to `config/seed_dev.php`. If
  * the `--file` option is present, it overrides everything else and
  * its value is used explicitly.
  *
  * @param Cake\ORM\Table $Table The Table instance to TRUNCATE.
  * @return bool True on success truncation, false on failure.
  */
 protected function truncateTable($Table)
 {
     $truncateSql = $Table->schema()->truncateSql($Table->connection())[0];
     $success = $Table->connection()->query($truncateSql);
     if ($success) {
         $this->verbose("<success>{$Table->alias()}: Existing DB records truncated.</success>");
     } else {
         $this->quiet("<warning>{$Table->alias()}: Can not truncate existing records.</warning>");
     }
     return $success;
 }
開發者ID:loadsys,項目名稱:cakephp-basic-seed,代碼行數:22,代碼來源:BasicSeedShell.php

示例3: testConnection

 /**
  * Tests connection method
  *
  * @return void
  */
 public function testConnection()
 {
     $table = new Table(['table' => 'users']);
     $this->assertNull($table->connection());
     $table->connection($this->connection);
     $this->assertSame($this->connection, $table->connection());
 }
開發者ID:jdaosavanh,項目名稱:clickerwebapp,代碼行數:12,代碼來源:TableTest.php

示例4: recover

 /**
  * Recovers the lft and right column values out of the hirearchy defined by the
  * parent column.
  *
  * @return void
  */
 public function recover()
 {
     $this->_table->connection()->transactional(function () {
         $this->_recoverTree();
     });
 }
開發者ID:ripzappa0924,項目名稱:carte0.0.1,代碼行數:12,代碼來源:TreeBehavior.php


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