本文整理匯總了PHP中TYPO3\CMS\Core\Tests\AccessibleObjectInterface::SELECTquery方法的典型用法代碼示例。如果您正苦於以下問題:PHP AccessibleObjectInterface::SELECTquery方法的具體用法?PHP AccessibleObjectInterface::SELECTquery怎麽用?PHP AccessibleObjectInterface::SELECTquery使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類TYPO3\CMS\Core\Tests\AccessibleObjectInterface
的用法示例。
在下文中一共展示了AccessibleObjectInterface::SELECTquery方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: multipleExpressiosInWhereClauseAreBracedCorrectly
/**
* @test
*/
public function multipleExpressiosInWhereClauseAreBracedCorrectly()
{
$listMaxExpressions = 1000;
$mockSpecificsOci8 = $this->getAccessibleMock('TYPO3\\CMS\\Dbal\\Database\\Specifics\\Oci8', array(), array(), '', FALSE);
$mockSpecificsOci8->expects($this->any())->method('getSpecific')->will($this->returnValue($listMaxExpressions));
$INitems = range(0, 1250);
$NOTINItems = range(0, 1001);
$where = 'uid = 1981 AND uid IN(' . implode(',', $INitems) . ') OR uid = 42 AND uid NOT IN(' . implode(',', $NOTINItems) . ')';
$result = $this->subject->SELECTquery('uid, pid', 'tt_content', $where);
$chunks = array_chunk($INitems, $listMaxExpressions);
$INItemsWhereExpr = array();
foreach ($chunks as $chunk) {
$INItemsWhereExpr[] = '"uid" IN (' . implode(',', $chunk) . ')';
}
$chunks = array_chunk($NOTINItems, $listMaxExpressions);
$NOTINItemsWhereExpr = array();
foreach ($chunks as $chunk) {
$NOTINItemsWhereExpr[] = '"uid" NOT IN (' . implode(',', $chunk) . ')';
}
/**
* $expectedWhere:
* "uid" = 1981 AND (
* "uid" IN (1,2,3,4,...,1000)
* OR "uid" IN (1001,1002,...,1250)
* ) OR "uid" = 42 AND (
* "uid" NOT IN (1,2,3,4,...,1000)
* AND "uid" NOT IN (1001)
* )
*/
$expectedWhere = '"uid" = 1981 AND (' . implode(' OR ', $INItemsWhereExpr) . ') OR "uid" = 42 AND (' . implode(' AND ', $NOTINItemsWhereExpr) . ')';
$expectedQuery = 'SELECT "uid", "pid" FROM "tt_content" WHERE ' . $expectedWhere;
$this->assertEquals($expectedQuery, $this->cleanSql($result));
}
示例2: notLikeBinaryOperatorIsKept
/**
* @test
* @see http://forge.typo3.org/issues/21514
*/
public function notLikeBinaryOperatorIsKept()
{
$result = $this->cleanSql($this->subject->SELECTquery('*', 'tt_content', 'bodytext NOT LIKE BINARY \'test\''));
$expected = 'SELECT * FROM tt_content WHERE bodytext NOT LIKE BINARY \'test\'';
$this->assertEquals($expected, $this->cleanSql($result));
}
示例3: notEqualAnsiOperatorCanBeParsed
/**
* @test
* @see http://forge.typo3.org/issues/32626
*/
public function notEqualAnsiOperatorCanBeParsed()
{
$result = $this->subject->SELECTquery('*', 'pages', 'pid<>3');
$expected = 'SELECT * FROM "pages" WHERE "pid" <> 3';
$this->assertEquals($expected, $this->cleanSql($result));
}
示例4: someCountFieldsInOrderByAreNotInGroupBy
/**
* @test
* @see http://forge.typo3.org/issues/43262
*/
public function someCountFieldsInOrderByAreNotInGroupBy()
{
$result = $this->subject->SELECTquery('COUNT(title), COUNT(pid)', 'pages', '', 'title', 'title, pid');
$expected = 'SELECT COUNT("title"), COUNT("pid") FROM "pages" GROUP BY "title" ORDER BY "title"';
$this->assertEquals($expected, $this->cleanSql($result));
}
示例5: singleQuotesAreProperlyEscaped
/**
* @test
* @see http://forge.typo3.org/issues/27760
*/
public function singleQuotesAreProperlyEscaped()
{
$result = $this->subject->SELECTquery('ISEC.phash', 'index_section ISEC, index_fulltext IFT', 'IFT.fulltextdata LIKE \'%' . $this->subject->quoteStr("Don't worry", 'index_fulltext') . '%\' AND ISEC.phash = IFT.phash', 'ISEC.phash');
$expected = 'SELECT "ISEC"."phash" FROM "index_section" "ISEC", "index_fulltext" "IFT" WHERE "IFT"."fulltextdata" LIKE \'%Don\'\'t worry%\' AND "ISEC"."phash" = "IFT"."phash" GROUP BY "ISEC"."phash"';
$this->assertEquals($expected, $this->cleanSql($result));
}
示例6: likeBinaryOperatorIsRemoved
/**
* @test
* @see http://forge.typo3.org/issues/21514
*/
public function likeBinaryOperatorIsRemoved()
{
$result = $this->subject->SELECTquery('*', 'tt_content', 'bodytext LIKE BINARY \'test\'');
$expected = 'SELECT * FROM "tt_content" WHERE (dbms_lob.instr("bodytext", \'test\',1,1) > 0)';
$this->assertEquals($expected, $this->cleanSql($result));
}
示例7: IfNullIsProperlyRemapped
/**
* @test
* @see http://forge.typo3.org/issues/17552
*/
public function IfNullIsProperlyRemapped()
{
$result = $this->subject->SELECTquery('*', 'tt_news_cat_mm', 'IFNULL(tt_news_cat_mm.uid_foreign,0) IN (21,22)');
$expected = 'SELECT * FROM "tt_news_cat_mm" WHERE ISNULL("tt_news_cat_mm"."uid_foreign", 0) IN (21,22)';
$this->assertEquals($expected, $this->cleanSql($result));
}