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
我是 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