将JSON数据插入postgresql查询成功,但输出是意外的

时间:2015-04-07 01:38:36

标签: sql json database postgresql

我正在尝试将一些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数据插入表中。查询成功完成,但是当我尝试查看表中的数据时,它只是一个管道。

这是输出: enter image description here

有人知道为什么这样的输出?知道我该怎么做才能纠正这个问题吗?

2 个答案:

答案 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()

中的小写字母

http://sqlfiddle.com/#!15/ec202/1