- カテゴリ:
半構造化データ関数 (型述語)
TYPEOF¶
VARIANT 列に保存されている値の型を報告します。型は文字列として返されます。
- こちらもご参照ください。
構文¶
TYPEOF( <expr> )
引数¶
expr
引数には、列名または一般式を指定できます。
戻り値¶
BOOLEAN
、 DECIMAL
、 ARRAY
、 OBJECT
など、入力式のデータ型を含んでいる VARCHAR を返します。
例¶
VARIANT 列内に保存された、さまざまな型のデータを含むテーブルを作成し、 TYPEOF
を使用して各データのデータ型を決定します。
テーブルを作成して入力します。
INSERT
ステートメントはPARSE_JSON
関数を使用します。create or replace table vartab (n number(2), v variant); insert into vartab select column1 as n, parse_json(column2) as v from values (1, 'null'), (2, null), (3, 'true'), (4, '-17'), (5, '123.12'), (6, '1.912e2'), (7, '"Om ara pa ca na dhih" '), (8, '[-1, 12, 289, 2188, false,]'), (9, '{ "x" : "abc", "y" : false, "z": 10} ') AS vals;データをクエリします。
select n, v, typeof(v) from vartab order by n; +---+------------------------+------------+ | N | V | TYPEOF(V) | |---+------------------------+------------| | 1 | null | NULL_VALUE | | 2 | NULL | NULL | | 3 | true | BOOLEAN | | 4 | -17 | INTEGER | | 5 | 123.12 | DECIMAL | | 6 | 1.912000000000000e+02 | DOUBLE | | 7 | "Om ara pa ca na dhih" | VARCHAR | | 8 | [ | ARRAY | | | -1, | | | | 12, | | | | 289, | | | | 2188, | | | | false, | | | | undefined | | | | ] | | | 9 | { | OBJECT | | | "x": "abc", | | | | "y": false, | | | | "z": 10 | | | | } | | +---+------------------------+------------+