我正在尝试将一些JSON数据插入postgresql中的表。
JSON DATA:
{
"wsgi.multiprocess": true,
"HTTP_REFERER": "http://localhost:9000/"
}
所以,要做到这一点,我正在做这些步骤:
CREATE TABLE TEST (MULTIPROCESS VARCHAR(20), HTTP_REFERER VARCHAR(50));
INSERT INTO TEST SELECT * FROM json_populate_record(NULL::test, '{"wsgi.multiprocess": true,"HTTP_REFERER": "http://localhost:9000/"}');
第一步创建一个表,而下一个表应该将JSON数据插入表中。查询成功完成,但是当我尝试查看表中的数据时,它只是一个管道。
这是输出:
有人知道为什么这样的输出?知道我该怎么做才能纠正这个问题吗?
答案 0 :(得分:3)
首先,在postgresql中如果你真的想要你的fieldname和table name是大写的,你需要像这样创建表:
CREATE TABLE "TEST" ("MULTIPROCESS" VARCHAR(20), "HTTP_REFERER" VARCHAR(50));
然后查询就像:
SELECT * FROM json_populate_record(NULL::"TEST", '{"wsgi.multiprocess": true,"HTTP_REFERER": "http://localhost:9000/"}');
MULTIPROCESS | HTTP_REFERER
--------------+------------------------
| http://localhost:9000/
如您所见,multiprocess留空,因为json和sql表中的字段名称不匹配。要摆脱它,你可以做一个外部脚本或postgresql函数。
例如:
CREATE OR REPLACE
FUNCTION replace_json_keys(IN js TEXT)
RETURNS json
STABLE
AS
$$
BEGIN
js := replace(js, '"wsgi.multiprocess"', '"MULTIPROCESS"');
return js::json;
END;
$$ LANGUAGE 'plpgsql';
然后,你可以这样做:
SELECT * FROM json_populate_record(NULL::"TEST", replace_json_keys('{"wsgi.multiprocess": true,"HTTP_REFERER": "http://localhost:9000/"}'));
MULTIPROCESS | HTTP_REFERER
--------------+------------------------
true | http://localhost:9000/
但是,最好的解决方案不是使用replace()
,而是使用json_each()
来分割两个数组中的键和值,在其中执行一个带有“case when”的循环来映射json键到sql键,然后返回一个新的json对象(json_object(keys[], values[])
)准备插入。
答案 1 :(得分:1)
json键应该与创建的表中的字段匹配(以“。”结尾的前缀被视为表名,没有它)
CREATE TABLE TEST (MULTIPROCESS VARCHAR(20), HTTP_REFERER VARCHAR(50));
INSERT INTO TEST SELECT MULTIPROCESS, HTTP_REFERER FROM json_populate_record(NULL::test, '{"multiprocess": true,"http_referer": "http://localhost:9000/"}');
http_referer应该是json_populate_record()
中的小写字母