postgresql存储过程输入json解析

postgresql stored procedure input json parsing

我是 PostgreSQL 的新手。这就是我想要实现的目标。我将得到一个 json 作为过程输入的文本,我需要在过程中解析它们以从中获取数据并将数据保存到 tables.

这是一个例子:

这是 table。

    CREATE TABLE json_test2
    (
      id serial primary key,
      name text,
      age int
    )     

现在我正在尝试创建一个程序,将包含 json.

的文本作为输入
    {
        "data": [
            {
                "name": "kumar",
                "age": 12
            },
            {
                "name": "anand",
                "age": 25
            }
        ]
    }

请创建一个满足我要求的过程

为什么需要 proc,它只是 Postgres 函数:

INSERT INTO table_name (name, age)
SELECT (rec->>'name')::text , (rec->>'age')::integer  FROM 
json_array_elements('{ "data": [ { "name": "kumar", "age": 12 }, { "name": "anand", "age": 25 } ] }'::json->'data' ) rec

http://www.postgresql.org/docs/9.3/static/functions-json.html

过程:

CREATE FUNCTION insert_from_json(in_json_txt json) RETURNS void AS
$BODY$
  INSERT INTO table_name (name, age)
  SELECT (rec->>'name')::text , (rec->>'age')::integer  FROM
  json_array_elements(in_json_txt->'data') rec
$BODY$
  LANGUAGE sql