assumeNotNull
도입 버전: v1.1.0
Nullable 타입 값에 대해, 해당하는 널을 허용하지 않는(Nullable이 아닌) 값을 반환합니다.
원래 값이 NULL인 경우 임의의 결과가 반환될 수 있습니다.
함수 ifNull 및 coalesce도 함께 참고하십시오.
구문
인자
반환 값
원래 값이 NULL이 아니면 널 허용이 아닌 값을 반환하며, 입력 값이 NULL이면 임의의 값을 반환합니다. Any
예시
사용 예시
CREATE TABLE t_null (x Int8, y Nullable(Int8))
ENGINE=MergeTree()
ORDER BY x;
INSERT INTO t_null VALUES (1, NULL), (2, 3);
SELECT assumeNotNull(y) FROM table;
SELECT toTypeName(assumeNotNull(y)) FROM t_null;
┌─assumeNotNull(y)─┐
│ 0 │
│ 3 │
└──────────────────┘
┌─toTypeName(assumeNotNull(y))─┐
│ Int8 │
│ Int8 │
└──────────────────────────────┘
coalesce
도입 버전: v1.1.0
가장 왼쪽에 위치한 NULL이 아닌 인자를 반환합니다.
구문
인수
x[, y, ...] — 임의 개수의 비복합(non-compound) 데이터 타입 인수입니다. 모든 인수는 서로 호환 가능한 데이터 타입이어야 합니다. Any
반환값
첫 번째로 NULL이 아닌 인수를 반환하며, 모든 인수가 NULL이면 NULL을 반환합니다. Any 또는 NULL
예시
사용 예시
-- Consider a list of contacts that may specify multiple ways to contact a customer.
CREATE TABLE aBook
(
name String,
mail Nullable(String),
phone Nullable(String),
telegram Nullable(UInt32)
)
ENGINE = MergeTree
ORDER BY tuple();
INSERT INTO aBook VALUES ('client 1', NULL, '123-45-67', 123), ('client 2', NULL, NULL, NULL);
-- The mail and phone fields are of type String, but the telegram field is UInt32 so it needs to be converted to String.
-- Get the first available contact method for the customer from the contact list
SELECT name, coalesce(mail, phone, CAST(telegram,'Nullable(String)')) FROM aBook;
┌─name─────┬─coalesce(mail, phone, CAST(telegram, 'Nullable(String)'))─┐
│ client 1 │ 123-45-67 │
│ client 2 │ ᴺᵁᴸᴸ │
└──────────┴───────────────────────────────────────────────────────────┘
firstNonDefault
도입된 버전: v25.9.0
인수 목록에서 기본값이 아닌 첫 번째 값을 반환합니다.
구문
firstNonDefault(arg1[, arg2[ ...]])
인수
arg1 — 검사할 첫 번째 인수 - arg2 — 검사할 두 번째 인수 - ... — 추가로 검사할 인수
반환 값
결과 타입은 모든 인수의 공통 슈퍼타입입니다.
예시
정수
SELECT firstNonDefault(0, 1, 2)
문자열
SELECT firstNonDefault('', 'hello', 'world')
NULL 값
SELECT firstNonDefault(NULL, 0 :: UInt8, 1 :: UInt8)
널 허용 0 값
SELECT firstNonDefault(NULL, 0 :: Nullable(UInt8), 1 :: Nullable(UInt8))
ifNull
도입: v1.1.0
첫 번째 인수가 NULL이면 대체 값을 반환합니다.
구문
인수
x — NULL 여부를 확인할 값입니다. Any
alt — x가 NULL일 때 함수가 반환하는 값입니다. Any
반환 값
x가 NULL이 아니면 x의 값을, 그렇지 않으면 alt를 반환합니다. Any
예시
사용 예시
SELECT ifNull('a', 'b'), ifNull(NULL, 'b');
┌─ifNull('a', 'b')─┬─ifNull(NULL, 'b')─┐
│ a │ b │
└──────────────────┴───────────────────┘
isNotNull
도입: v1.1.0
인수가 NULL이 아닌지 확인합니다.
연산자 IS NOT NULL도 참고하십시오.
구문
인수
x — 복합 타입이 아닌 데이터 타입의 값. Any
반환 값
x가 NULL이 아니면 1, 그렇지 않으면 0을 반환합니다. UInt8
예시
사용 예시
CREATE TABLE t_null
(
x Int32,
y Nullable(Int32)
)
ENGINE = MergeTree
ORDER BY tuple();
INSERT INTO t_null VALUES (1, NULL), (2, 3);
SELECT x FROM t_null WHERE isNotNull(y);
isNull
도입: v1.1.0
인수가 NULL인지 확인합니다.
관련 항목: 연산자 IS NULL.
구문
인수
x — 복합형이 아닌 데이터 타입의 값. Any
반환 값
x가 NULL이면 1, 그렇지 않으면 0을 반환합니다. UInt8
예시
사용 예시
CREATE TABLE t_null
(
x Int32,
y Nullable(Int32)
)
ENGINE = MergeTree
ORDER BY tuple();
INSERT INTO t_null VALUES (1, NULL), (2, 3);
SELECT x FROM t_null WHERE isNull(y);
isNullable
도입 버전: v22.7.0
인수의 데이터 타입이 널 허용(Nullable)인지(즉, NULL 값을 허용하는지) 확인합니다.
구문
인수
x — 어떤 데이터 타입이든 될 수 있는 값. Any
반환 값
x가 널 허용(Nullable) 데이터 타입이면 1, 그렇지 않으면 0을 반환합니다. UInt8
예시
사용 예시
CREATE TABLE tab (
ordinary_col UInt32,
nullable_col Nullable(UInt32)
)
ENGINE = MergeTree
ORDER BY tuple();
INSERT INTO tab (ordinary_col, nullable_col) VALUES (1,1), (2, 2), (3,3);
SELECT isNullable(ordinary_col), isNullable(nullable_col) FROM tab;
┌───isNullable(ordinary_col)──┬───isNullable(nullable_col)──┐
│ 0 │ 1 │
│ 0 │ 1 │
│ 0 │ 1 │
└─────────────────────────────┴─────────────────────────────┘
isZeroOrNull
도입된 버전: v20.3.0
인수가 0 또는 NULL인지 확인합니다.
구문
인수
반환 값
x가 NULL이거나 0이면 1을, 그렇지 않으면 0을 반환합니다. UInt8/16/32/64 또는 Float32/Float64
예시
사용 예시
CREATE TABLE t_null
(
x Int32,
y Nullable(Int32)
)
ENGINE = MergeTree
ORDER BY tuple();
INSERT INTO t_null VALUES (1, NULL), (2, 0), (3, 3);
SELECT x FROM t_null WHERE isZeroOrNull(y);
nullIf
도입된 버전: v1.1.0
두 인수가 같으면 NULL을 반환합니다.
구문
인수
x — 첫 번째 값. Any
y — 두 번째 값. Any
반환값
두 인수가 같으면 NULL을 반환하고, 그렇지 않으면 첫 번째 인수를 반환합니다. NULL 또는 Nullable(x)
예시
사용 예시
SELECT nullIf(1, 1), nullIf(1, 2);
┌─nullIf(1, 1)─┬─nullIf(1, 2)─┐
│ ᴺᵁᴸᴸ │ 1 │
└──────────────┴──────────────┘
toNullable
도입 버전: v1.1.0
지정된 인수의 타입을 Nullable(널 허용)로 변환합니다.
구문
인자
x — 모든 비복합(non-compound) 타입의 값. Any
반환 값
입력 값을 널 허용(Nullable) 타입으로 변환하여 반환합니다. Nullable(Any)
예시
사용 예시
SELECT toTypeName(10), toTypeName(toNullable(10));
┌─toTypeName(10)─┬─toTypeName(toNullable(10))─┐
│ UInt8 │ Nullable(UInt8) │
└────────────────┴────────────────────────────┘