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


PHP DboSource::calculate方法代碼示例

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


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

示例1: testVirtualFieldsInCalculate

 /**
  * test calculate to generate claculate statements on virtual fields
  *
  * @return void
  */
 function testVirtualFieldsInCalculate()
 {
     $Article = ClassRegistry::init('Article');
     $Article->virtualFields = array('this_moment' => 'NOW()', 'two' => '1 + 1', 'comment_count' => 'SELECT COUNT(*) FROM ' . $this->Dbo->fullTableName('comments') . ' WHERE Article.id = ' . $this->Dbo->fullTableName('comments') . '.article_id');
     $result = $this->Dbo->calculate($Article, 'count', array('this_moment'));
     $expected = 'COUNT(NOW()) AS `count`';
     $this->assertEqual($expected, $result);
     $result = $this->Dbo->calculate($Article, 'max', array('comment_count'));
     $expected = 'MAX(SELECT COUNT(*) FROM comments WHERE `Article`.`id` = `comments`.`article_id`) AS `comment_count`';
     $this->assertEqual($expected, $result);
 }
開發者ID:no2key,項目名稱:Web-Framework-Benchmark,代碼行數:16,代碼來源:dbo_mysql.test.php

示例2: testVirtualFieldsInCalculate

 /**
  * test calculate to generate claculate statements on virtual fields
  *
  * @return void
  */
 public function testVirtualFieldsInCalculate()
 {
     $Boat = ClassRegistry::init('Boat');
     $commentsTable = $this->Dbo->fullTableName('comments', false, false);
     $Boat->virtualFields = array('this_moment' => 'NOW()', 'two' => '1 + 1', 'comment_count' => 'SELECT COUNT(*) FROM ' . $commentsTable . ' WHERE Boat.id = ' . $commentsTable . '.article_id');
     $result = $this->Dbo->calculate($Boat, 'count', array('this_moment'));
     $expected = 'COUNT(NOW()) AS `count`';
     $this->assertEquals($expected, $result);
     $result = $this->Dbo->calculate($Boat, 'max', array('comment_count'));
     $expected = "MAX(SELECT COUNT(*) FROM {$commentsTable} WHERE `Boat`.`id` = `{$commentsTable}`.`article_id`) AS `comment_count`";
     $this->assertEquals($expected, $result);
 }
開發者ID:saikais,項目名稱:cruise,代碼行數:17,代碼來源:MysqlTest.php


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