メインコンテンツへスキップ
メインコンテンツへスキップ

NULL 可能な値を扱う関数

assumeNotNull

導入バージョン: v1.1

Nullable の値に対して、対応する非 Nullable 型の値を返します。 元の値が NULL の場合、不定の結果が返されることがあります。

関連項目: 関数 ifNullcoalesce

構文

assumeNotNull(x)

引数

  • x — 任意の Nullable 型の元の値。Nullable(T)

戻り値

元の値が NULL でない場合は非 Nullable 型の値を返し、入力値が NULL の場合は任意の値を返します。Any

使用例

```sql title=クエリ
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 ではない引数を返します。

構文

coalesce(x[, y, ...])

引数

  • x[, y, ...] — 任意個数の非複合型パラメータ。すべてのパラメータは互いに互換性のあるデータ型である必要があります。Any

戻り値

最初の NULL ではない引数を返します。すべての引数が NULL の場合は NULL を返します。Any または NULL

使用例

-- 顧客への複数の連絡方法を指定可能な連絡先リストを考えます。

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);

-- mailフィールドとphoneフィールドはString型ですが、telegramフィールドはUInt32型のため、String型への変換が必要です。

-- 連絡先リストから顧客の利用可能な最初の連絡方法を取得します

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

引数の中から、デフォルト値ではない最初の値を返します。

構文

引数

  • arg1 — 確認する最初の引数 - arg2 — 確認する2番目の引数 - ... — 確認する追加の引数

返り値

結果の型は、すべての引数のスーパータイプになります

整数

SELECT firstNonDefault(0, 1, 2)
1

文字列

SELECT firstNonDefault('', 'hello', 'world')
'hello'

NULL 値

SELECT firstNonDefault(NULL, 0 :: UInt8, 1 :: UInt8)
1

NULL 許容ゼロ

SELECT firstNonDefault(NULL, 0 :: Nullable(UInt8), 1 :: Nullable(UInt8))
0

ifNull

導入バージョン: v1.1

最初の引数が NULL の場合に、代わりの値を返します。

構文

ifNull(x, alt)

引数

  • xNULL かどうかをチェックする値。Any
  • altxNULL の場合に関数が返す値。Any

返される値

xNULL でない場合は x の値を返し、それ以外の場合は alt を返します。Any

使用例

SELECT ifNull('a', 'b'), ifNull(NULL, 'b');
┌─ifNull('a', 'b')─┬─ifNull(NULL, 'b')─┐
│ a                │ b                 │
└──────────────────┴───────────────────┘

isNotNull

導入: v1.1

引数が NULL でないかどうかを判定します。

関連項目: 演算子 IS NOT NULL

構文

isNotNull(x)

引数

  • x — 非複合データ型の値。Any

戻り値

xNULL でない場合は 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);
┌─x─┐
│ 2 │
└───┘

isNull

導入バージョン: v1.1

引数が NULL かどうかをチェックします。

関連項目: 演算子 IS NULL

構文

isNull(x)

引数

  • x — 非複合データ型の値。Any

戻り値

xNULL の場合は 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);
┌─x─┐
│ 1 │
└───┘

isNullable

導入: v22.7

引数のデータ型が NullableNULL 値を許容する型)かどうかを判定します。

構文

isNullable(x)

引数

  • x — 任意のデータ型の値。Any

戻り値

xNullable データ型であれば 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 かどうかをチェックします。

構文

isZeroOrNull(x)

引数

  • x — 数値型の値。UInt

返される値

xNULL またはゼロに等しい場合は 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);
┌─x─┐
│ 1 │
│ 2 │
└───┘

nullIf

導入バージョン: v1.1

2つの引数が等しい場合、NULL を返します。

構文

nullIf(x, y)

引数

  • x — 1つ目の値。Any
  • y — 2つ目の値。Any

戻り値

両方の引数が同じ値の場合は NULL を返し、それ以外の場合は 1つ目の引数を返します。NULL または Nullable(x)

使用例

SELECT nullIf(1, 1), nullIf(1, 2);
┌─nullIf(1, 1)─┬─nullIf(1, 2)─┐
│         ᴺᵁᴸᴸ │            1 │
└──────────────┴──────────────┘

toNullable

導入バージョン: v1.1

指定された引数の型を Nullable 型に変換します。

構文

toNullable(x)

引数

  • x — 任意の非複合型の値。Any

戻り値

入力値と同じ値を返すが、その型は Nullable となる。Nullable(Any)

使用例

SELECT toTypeName(10), toTypeName(toNullable(10));
┌─toTypeName(10)─┬─toTypeName(toNullable(10))─┐
│ UInt8          │ Nullable(UInt8)            │
└────────────────┴────────────────────────────┘