Final Class Yiisoft\Db\Pgsql\Builder\JsonOverlapsBuilder
| Inheritance | Yiisoft\Db\Pgsql\Builder\JsonOverlapsBuilder |
|---|---|
| Implements | Yiisoft\Db\Expression\ExpressionBuilderInterface |
Builds expressions for {@see JsonOverlaps} for PostgreSQL Server.
Public Methods
| Method | Description | Defined By |
|---|---|---|
| __construct() | Yiisoft\Db\Pgsql\Builder\JsonOverlapsBuilder | |
| build() | Build SQL for {@see JsonOverlaps}. | Yiisoft\Db\Pgsql\Builder\JsonOverlapsBuilder |
Method Details
| public mixed __construct ( \Yiisoft\Db\QueryBuilder\QueryBuilderInterface $queryBuilder ) | ||
| $queryBuilder | \Yiisoft\Db\QueryBuilder\QueryBuilderInterface | |
public function __construct(
private readonly QueryBuilderInterface $queryBuilder,
) {}
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[]";
}
Signup or Login in order to comment.