0 follower

Final Class Yiisoft\Db\Pgsql\Builder\JsonOverlapsBuilder

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

Builds expressions for {@see JsonOverlaps} for PostgreSQL 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

                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 JsonValue) {
        /** @psalm-suppress MixedArgument */
        $values = new ArrayValue($values->value);
    } elseif (!$values instanceof ExpressionInterface) {
        $values = new ArrayValue($values);
    }
    $values = $this->queryBuilder->buildExpression($values, $params);
    if (preg_match('/::\w+\[]$/', $values, $matches) === 1) {
        $typeHint = $matches[0];
        return "ARRAY(SELECT jsonb_array_elements_text($column::jsonb))$typeHint && $values";
    }
    return "ARRAY(SELECT jsonb_array_elements_text($column::jsonb)) && $values::text[]";
}