TYPO3 CMS  TYPO3_8-7
LikeWildcard.php
Go to the documentation of this file.
1 <?php
3 
4 /*
5  * This file is part of the TYPO3 CMS project.
6  *
7  * It is free software; you can redistribute it and/or modify it under
8  * the terms of the GNU General Public License, either version 2
9  * of the License, or any later version.
10  *
11  * For the full copyright and license information, please read the
12  * LICENSE.txt file that was distributed with this source code.
13  *
14  * The TYPO3 project - inspiring people to share!
15  */
18 
23 {
24  const __default = self::BOTH;
25 
27  const NONE = 0;
28 
30  const LEFT = 1;
31 
33  const RIGHT = 2;
34 
36  const BOTH = 3;
37 
46  public function getLikeQueryPart($tableName, $fieldName, $likeValue)
47  {
48  $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)
49  ->getQueryBuilderForTable($tableName);
50 
51  $string = ($this->value & self::LEFT ? '%' : '')
52  . $queryBuilder->escapeLikeWildcards($likeValue)
53  . ($this->value & self::RIGHT ? '%' : '');
54 
55  return $queryBuilder->expr()->like($fieldName, $queryBuilder->quote($string));
56  }
57 }
getLikeQueryPart($tableName, $fieldName, $likeValue)
static makeInstance($className,... $constructorArguments)