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


PHP ModelCriteria::joinWith方法代碼示例

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


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

示例1: testFindOneWithDistantClassRenamedRelation

 public function testFindOneWithDistantClassRenamedRelation()
 {
     BookstoreDataPopulator::populate();
     BookTableMap::clearInstancePool();
     AuthorTableMap::clearInstancePool();
     ReviewTableMap::clearInstancePool();
     Propel::enableInstancePooling();
     $c = new ModelCriteria('bookstore', 'Propel\\Tests\\Bookstore\\BookSummary');
     $c->joinWith('Propel\\Tests\\Bookstore\\BookSummary.SummarizedBook');
     $c->joinWith('SummarizedBook.Author');
     $c->setFormatter(ModelCriteria::FORMAT_ON_DEMAND);
     $con = Propel::getServiceContainer()->getConnection(BookTableMap::DATABASE_NAME);
     $summary = $c->findOne($con);
     $count = $con->getQueryCount();
     $this->assertEquals('Harry Potter does some amazing magic!', $summary->getSummary(), 'Main object is correctly hydrated');
     $book = $summary->getSummarizedBook();
     $this->assertEquals($count, $con->getQueryCount(), 'with() hydrates the related objects to save a query');
     $this->assertEquals('Harry Potter and the Order of the Phoenix', $book->getTitle(), 'Related object is correctly hydrated');
     $author = $book->getAuthor();
     $this->assertEquals($count, $con->getQueryCount(), 'with() hydrates the related objects to save a query');
     $this->assertEquals('J.K.', $author->getFirstName(), 'Related object is correctly hydrated');
 }
開發者ID:kalaspuffar,項目名稱:php-orm-benchmark,代碼行數:22,代碼來源:OnDemandFormatterWithTest.php

示例2: testFindOneWithColumnAndAlias

 public function testFindOneWithColumnAndAlias()
 {
     BookstoreDataPopulator::populate();
     BookTableMap::clearInstancePool();
     AuthorTableMap::clearInstancePool();
     ReviewTableMap::clearInstancePool();
     $c = new ModelCriteria('bookstore', 'Propel\\Tests\\Bookstore\\Book');
     $c->filterByTitle('Harry Potter and the Order of the Phoenix');
     $c->joinWith('Propel\\Tests\\Bookstore\\Book.BookSummary');
     $c->joinWith('Propel\\Tests\\Bookstore\\Book.Review');
     $c->join('Propel\\Tests\\Bookstore\\Book.Author');
     $c->withColumn('Author.FirstName', 'AuthorName');
     $con = Propel::getServiceContainer()->getConnection(BookTableMap::DATABASE_NAME);
     $book = $c->find($con)->get(0);
     $count = $con->getQueryCount();
     $reviews = $book->getReviews();
     //Washington Post
     $this->assertTrue($book instanceof Book, 'withColumn() do not change the resulting model class');
     $this->assertEquals(2, count($reviews), 'Related objects are correctly hydrated');
     $this->assertEquals($count, $con->getQueryCount(), 'with() hydrates the related objects to save a query ');
     $this->assertEquals('J.K.', $book->getVirtualColumn('AuthorName'), 'ObjectFormatter adds withColumns as virtual columns');
 }
開發者ID:disider,項目名稱:Propel2,代碼行數:22,代碼來源:ObjectFormatterWithTest.php

示例3: testUseQueryJoinWithFind

 public function testUseQueryJoinWithFind()
 {
     $c = new ModelCriteria('bookstore', 'Propel\\Tests\\Bookstore\\Review');
     $c->joinWith('Book');
     $c2 = $c->useQuery('Book');
     $joins = $c->getJoins();
     $this->assertEquals($c->getPreviousJoin(), null, 'The default value for previousJoin remains null');
     $this->assertEquals($c2->getPreviousJoin(), $joins['Book'], 'useQuery() sets the previousJoin');
     // join Book with Author, which is possible since previousJoin is set, which makes resolving of relations possible during hydration
     $c2->joinWith('Author');
     $c = $c2->endUse();
     $con = Propel::getServiceContainer()->getConnection(BookTableMap::DATABASE_NAME);
     $c->find($con);
     $expectedSQL = $this->getSql("SELECT review.id, review.reviewed_by, review.review_date, review.recommended, review.status, review.book_id, book.id, book.title, book.isbn, book.price, book.publisher_id, book.author_id, author.id, author.first_name, author.last_name, author.email, author.age FROM review INNER JOIN book ON (review.book_id=book.id) INNER JOIN author ON (book.author_id=author.id)");
     $this->assertEquals($expectedSQL, $con->getLastExecutedQuery(), 'useQuery() and joinWith() can be used together and form a correct query');
 }
開發者ID:dracony,項目名稱:forked-php-orm-benchmark,代碼行數:16,代碼來源:ModelCriteriaTest.php


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