in
Предикат
Возвращает значение true
, если elem
равно любому exprN
или строке в query
.
Синтаксис
elem in ( expr1 [, ...] )
elem in ( query )
Аргументы
-
elem
: выражение любого сравнимого типа. -
exprN
: выражение любого типа, совместно используемое наименее распространенным типом со всеми другими аргументами. -
query
: любой запрос. Результат должен иметь наименьший общий тип сelem
. Если запрос возвращает несколько столбцовelem
, должен быть кортеж (STRUCT) с тем же количеством полей.
Возвращает
Результатом является ЛОГИЧЕСКОЕ ЗНАЧЕНИЕ.
Примеры
> SELECT 1 in(1, 2, 3);
true
> SELECT 1 in(2, 3, 4);
false
> SELECT (1, 2) IN ((1, 2), (2, 3));
true
> SELECT named_struct('a', 1, 'b', 2) in(named_struct('a', 1, 'b', 1), named_struct('a', 1, 'b', 3));
false
> SELECT named_struct('a', 1, 'b', 2) in(named_struct('a', 1, 'b', 2), named_struct('a', 1, 'b', 3));
true
> SELECT 1 IN (SELECT * FROM VALUES(1), (2));
true;
> SELECT (1, 2) IN (SELECT c1, c2 FROM VALUES(1, 2), (3, 4) AS T(c1, c2));
true;