是否可以在不创建函数且不使用任何服务器端编程语言的情况下转换postgresql 9.4 jsonb数据?
CREATE TABLE test (id SERIAL PRIMARY KEY,data JSONB);
INSERT INTO test(data) VALUES('{"a":1,"b":2}');
INSERT INTO test(data) VALUES('{"a":3,"b":4,"c":7}');
INSERT INTO test(data) VALUES('{"a":5,"b":5,"d":8}');
SELECT * FROM test;
id | data
----+-------------------------
1 | {"a": 1, "b": 2}
2 | {"a": 3, "b": 4, "c": 7}
3 | {"a": 5, "b": 5, "d": 8}
将其转换为:
{1:[1,2,null,null],2:[3,4,7,null],3:[5,5,null,8]}
答案 0 :(得分:11)
将 jsonb_populate_record()
(或json_populate_record()
用于json
)与众所周知的行类型作为目标。您可以使用临时表来注册类型以供临时使用(如果您不能使用现有表或自定义复合类型):
CREATE TEMP TABLE obj(a int, b int, c int, d int);
然后:
SELECT t.id, d.*
FROM test t
, jsonb_populate_record(null::obj, t.data) d;
或使用 jsonb_to_record()
(或json_to_record()
json
)并提供一个列定义列表,其中包含以下呼叫:
SELECT t.id, d.*
FROM test t
, jsonb_to_record(t.data) d(a int, b int, c int, d int);
或分别提取并投射每个字段:
SELECT id, (data->>'a')::int AS a, (data->>'b')::int AS b
, (data->>'c')::int AS c, (data->>'d')::int AS d
FROM test;
所有这三项都适用于json
和jsonb
。只需使用相应的功能变体即可。
相关: