Función OBJECT - Amazon Redshift

Función OBJECT

Crea un objeto del tipo de datos SUPER.

Sintaxis

OBJECT ( [ key1, value1 ], [ key2, value2 ...] )

Argumentos

key1, key2

Expresiones que se evalúan como cadenas de tipo VARCHAR.

value1, value2

Expresiones de cualquier tipo de datos de Amazon Redshift, excepto los datetime, ya que Amazon Redshift no convierte los tipos de datetime al tipo de datos SUPER. Para obtener más información sobre los tipos de datetime, consulte Tipos de fecha y hora.

Las expresiones value en un objeto no tienen que ser del mismo tipo de datos.

Tipo de devolución

SUPER

Ejemplo

-- Creates an empty object. select object(); object -------- {} (1 row) -- Creates objects with different keys and values. select object('a', 1, 'b', true, 'c', 3.14); object --------------------------- {"a":1,"b":true,"c":3.14} (1 row) select object('a', object('aa', 1), 'b', array(2,3), 'c', json_parse('{}')); object --------------------------------- {"a":{"aa":1},"b":[2,3],"c":{}} (1 row) -- Creates objects using columns from a table. create table bar (k varchar, v super); insert into bar values ('k1', json_parse('[1]')), ('k2', json_parse('{}')); select object(k, v) from bar; object ------------ {"k1":[1]} {"k2":{}} (2 rows) -- Errors out because DATE type values can't be converted to SUPER type. select object('k', '2008-12-31'::date); ERROR: OBJECT could not convert type date to super