assumeNotNull
導入バージョン: v1.1
型 Nullable の値に対応する非 Nullable 値を返します。
元の値が NULL の場合、任意の値が返される可能性があります。
関連項目: 関数 ifNull、coalesce。
構文
引数
返される値
元の値が NULL でない場合は Nullable ではない値を返し、入力値が 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
最も左側にある NULL ではない引数を返します。
構文
引数
x[, y, ...] — 任意個数の非複合型のパラメータ。すべてのパラメータは互いに互換性のあるデータ型である必要があります。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
一連の引数の中から、最初にデフォルト値ではない値を返します。
構文
firstNonDefault(arg1[, arg2[ ...]])
引数
arg1 — チェック対象となる最初の引数 - arg2 — チェック対象となる 2 番目の引数 - ... — チェック対象となる追加の引数
返される値
結果の型は、すべての引数のスーパータイプです
例
整数
SELECT firstNonDefault(0, 1, 2)
文字列
SELECT firstNonDefault('', 'hello', 'world')
NULL 値
SELECT firstNonDefault(NULL, 0 :: UInt8, 1 :: UInt8)
Nullable のゼロ
SELECT firstNonDefault(NULL, 0 :: Nullable(UInt8), 1 :: Nullable(UInt8))
ifNull
導入バージョン: v1.1
最初の引数が NULL の場合に、代わりの値を返します。
構文
引数
x — NULL かどうかをチェックする値。Any
alt — x が NULL の場合に関数が返す値。Any
戻り値
x が NULL でない場合は x の値を返し、NULL の場合は alt を返します。Any
例
使用例
SELECT ifNull('a', 'b'), ifNull(NULL, 'b');
┌─ifNull('a', 'b')─┬─ifNull(NULL, 'b')─┐
│ a │ b │
└──────────────────┴───────────────────┘
isNotNull
導入バージョン: v1.1
引数が NULL でないことを確認します。
併せて参照: 演算子 IS NOT NULL。
構文
引数
戻り値
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
引数が NULL かどうかを判定します。
関連項目: 演算子 IS NULL。
構文
引数
戻り値
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
引数のデータ型が Nullable かどうか(つまり NULL 値を許容するかどうか)をチェックします。
構文
引数
戻り値
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)または 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
両方の引数が等しい場合に NULL を返します。
構文
引数
戻り値
両方の引数が同じ値である場合は NULL を返し、それ以外の場合は最初の引数を返します。NULL または Nullable(x)
例
使用例
SELECT nullIf(1, 1), nullIf(1, 2);
┌─nullIf(1, 1)─┬─nullIf(1, 2)─┐
│ ᴺᵁᴸᴸ │ 1 │
└──────────────┴──────────────┘
toNullable
導入: v1.1
指定された引数の型を Nullable に変換します。
構文
引数
返り値
入力値と同じ値を Nullable 型で返します。Nullable(Any)
例
使用例
SELECT toTypeName(10), toTypeName(toNullable(10));
┌─toTypeName(10)─┬─toTypeName(toNullable(10))─┐
│ UInt8 │ Nullable(UInt8) │
└────────────────┴────────────────────────────┘