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


PHP Query::decorateResults方法代碼示例

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


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

示例1: testDecorateResults

 /**
  * Tests stacking decorators for results and resetting the list of decorators
  *
  * @return void
  */
 public function testDecorateResults()
 {
     $query = new Query($this->connection);
     $result = $query->select(['id', 'title'])->from('articles')->order(['id' => 'ASC'])->decorateResults(function ($row) {
         $row['modified_id'] = $row['id'] + 1;
         return $row;
     })->execute();
     while ($row = $result->fetch('assoc')) {
         $this->assertEquals($row['id'] + 1, $row['modified_id']);
     }
     $result = $query->decorateResults(function ($row) {
         $row['modified_id']--;
         return $row;
     })->execute();
     while ($row = $result->fetch('assoc')) {
         $this->assertEquals($row['id'], $row['modified_id']);
     }
     $result = $query->decorateResults(function ($row) {
         $row['foo'] = 'bar';
         return $row;
     }, true)->execute();
     while ($row = $result->fetch('assoc')) {
         $this->assertEquals('bar', $row['foo']);
         $this->assertArrayNotHasKey('modified_id', $row);
     }
     $results = $query->decorateResults(null, true)->execute();
     while ($row = $result->fetch('assoc')) {
         $this->assertArrayNotHasKey('foo', $row);
         $this->assertArrayNotHasKey('modified_id', $row);
     }
 }
開發者ID:KarimaLadhani,項目名稱:cakephp,代碼行數:36,代碼來源:QueryTest.php

示例2: _pagingSubquery

 /**
  * Generate a paging subquery for older versions of Oracle Server.
  *
  * Prior to Oracle 12 there was no equivalent to LIMIT OFFSET,
  * so a subquery must be used.
  *
  * @param \Cake\Database\Query $original The query to wrap in a subquery.
  * @param int $limit The number of rows to fetch.
  * @param int $offset The number of rows to offset.
  * @return \Cake\Database\Query Modified query object.
  */
 protected function _pagingSubquery($original, $limit, $offset)
 {
     $field = 'cake_paging_out."_cake_page_rownum_"';
     $query = clone $original;
     $query->limit(null)->offset(null);
     $outer = new Query($query->connection());
     $outer->select(['cake_paging.*', '_cake_page_rownum_' => new SimpleExpression('ROWNUM')])->from(['cake_paging' => $query]);
     $outer2 = new Query($query->connection());
     $outer2->select('*')->from(['cake_paging_out' => $outer]);
     if ($offset) {
         $outer2->where(["{$field} > " . (int) $offset]);
     }
     if ($limit) {
         $value = (int) $offset + (int) $limit;
         $outer2->where(["{$field} <= {$value}"]);
     }
     $original->decorateResults(function ($row) {
         if (isset($row['_cake_page_rownum_'])) {
             unset($row['_cake_page_rownum_']);
         }
         return $row;
     });
     return $outer2;
 }
開發者ID:cakedc,項目名稱:cakephp-oracle-driver,代碼行數:35,代碼來源:OracleDialectTrait.php

示例3: _transformDistinct

 /**
  * Returns the passed query after rewriting the DISTINCT clause, so that drivers
  * that do not support the "ON" part can provide the actual way it should be done
  *
  * @param \Cake\Database\Query $original The query to be transformed
  * @return \Cake\Database\Query
  */
 protected function _transformDistinct($original)
 {
     if (!is_array($original->clause('distinct'))) {
         return $original;
     }
     $query = clone $original;
     $distinct = $query->clause('distinct');
     $query->distinct(false);
     $order = new OrderByExpression($distinct);
     $query->select(function ($q) use($distinct, $order) {
         $over = $q->newExpr('ROW_NUMBER() OVER')->add('(PARTITION BY')->add($q->newExpr()->add($distinct)->tieWith(','))->add($order)->add(')')->tieWith(' ');
         return ['_cake_distinct_pivot_' => $over];
     })->limit(null)->offset(null)->order([], true);
     $outer = new Query($query->connection());
     $outer->select('*')->from(['_cake_distinct_' => $query])->where(['_cake_distinct_pivot_' => 1]);
     // Decorate the original query as that is what the
     // end developer will be calling execute() on originally.
     $original->decorateResults(function ($row) {
         if (isset($row['_cake_distinct_pivot_'])) {
             unset($row['_cake_distinct_pivot_']);
         }
         return $row;
     });
     return $outer;
 }
開發者ID:CakeDC,項目名稱:cakephp,代碼行數:32,代碼來源:SqlserverDialectTrait.php

示例4: _pagingSubquery

 /**
  * Generate a paging subquery for older versions of SQLserver.
  *
  * Prior to SQLServer 2012 there was no equivalent to LIMIT OFFSET, so a subquery must
  * be used.
  *
  * @param \Cake\Database\Query $original The query to wrap in a subquery.
  * @param int $limit The number of rows to fetch.
  * @param int $offset The number of rows to offset.
  * @return \Cake\Database\Query Modified query object.
  */
 protected function _pagingSubquery($original, $limit, $offset)
 {
     $field = '_cake_paging_._cake_page_rownum_';
     $query = clone $original;
     $order = $query->clause('order') ?: new OrderByExpression('NULL');
     $query->select(['_cake_page_rownum_' => new UnaryExpression('ROW_NUMBER() OVER', $order)])->limit(null)->offset(null)->order([], true);
     $outer = new Query($query->connection());
     $outer->select('*')->from(['_cake_paging_' => $query]);
     if ($offset) {
         $outer->where(["{$field} >" => $offset]);
     }
     if ($limit) {
         $outer->where(["{$field} <=" => (int) $offset + (int) $limit]);
     }
     // Decorate the original query as that is what the
     // end developer will be calling execute() on originally.
     $original->decorateResults(function ($row) {
         if (isset($row['_cake_page_rownum_'])) {
             unset($row['_cake_page_rownum_']);
         }
         return $row;
     });
     return $outer;
 }
開發者ID:maitrepylos,項目名稱:nazeweb,代碼行數:35,代碼來源:SqlserverDialectTrait.php


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