0 follower

Final Class Yiisoft\Db\Sqlite\Builder\JsonOverlapsBuilder

InheritanceYiisoft\Db\Sqlite\Builder\JsonOverlapsBuilder
ImplementsYiisoft\Db\Expression\ExpressionBuilderInterface

Builds expressions for {@see JsonOverlapsCondition} for SQLite Server.

Method Details

Hide inherited methods

__construct() public method

public mixed __construct ( \Yiisoft\Db\QueryBuilder\QueryBuilderInterface $queryBuilder )
$queryBuilder \Yiisoft\Db\QueryBuilder\QueryBuilderInterface

                public function __construct(
    private readonly QueryBuilderInterface $queryBuilder,
) {}

            
build() public method

Build SQL for {@see JsonOverlaps}.

public string build ( \Yiisoft\Db\QueryBuilder\Condition\JsonOverlaps $expression, array &$params = [] )
$expression \Yiisoft\Db\QueryBuilder\Condition\JsonOverlaps

The {@see \Yiisoft\Db\QueryBuilder\Condition\JsonOverlaps} to be built.

$params array
throws \Yiisoft\Db\Exception\Exception
throws InvalidArgumentException
throws \Yiisoft\Db\Exception\InvalidConfigException
throws \Yiisoft\Db\Exception\NotSupportedException

                public function build(ExpressionInterface $expression, array &$params = []): string
{
    $column = $expression->column instanceof ExpressionInterface
        ? $this->queryBuilder->buildExpression($expression->column)
        : $this->queryBuilder->getQuoter()->quoteColumnName($expression->column);
    $values = $expression->values;
    if (!$values instanceof ExpressionInterface) {
        $values = new JsonValue($values);
    }
    $values = $this->queryBuilder->buildExpression($values, $params);
    return "EXISTS(SELECT value FROM json_each($column) INTERSECT SELECT value FROM json_each($values))=1";
}