sql - 从 postgreSQL 中的 JSON 数组获取单个元素

标签 sql arrays json postgresql stored-functions

我需要根据我定义的一些规则从存储在 postgreSQL 数据库中的数组中检索单个元素,然后将它与其他一些数据连接起来。让我举个例子:

postgres=# SELECT * FROM list;
id    | list
------+-----------------------------------------------------------------------------
0ab2c | [{type: 1, val: a}, {type: 3, val: c}, {type: 4, val: d}]
01abc | [{type: 1, val: a}, {type: 2, val: b}]
a0b31 | [{type: 1, val: a}, {type: 2, val: b}, {type: 3, val: c}]

postgres=# SELECT * FROM elems
eid | listId
----+-------
10  | 0ab2c
11  | 01abc
12  | a0b31

我想从 list 表中提取一个元素,然后将结果与 elem 表连接起来,以获得如下内容:

eid | listId | type | val
----+--------+------+-----
10  | 0ab2c  |   3  |  c
11  | 01abc  |   2  |  b
12  | a0b31  |   2  |  b

特别是json数组中的元素应该根据一个函数来选择(我用JS写的,因为我比较熟悉,但是这个函数当然需要在plpgSQL中):

function getElemFromList(list){
    var allowedTypes = [2, 3];
    var result;
    for(var i = 0; i < list.length; i++){
        if(list[i].indexOf(allowedTypes) !== -1){
            return list[i];
        }
    }
}

列表中的元素属于特定类型并且是数组中第一个允许的元素。

最佳答案

这应该很简单。看起来您需要此页面中的运算符:

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

如果你想遍历 pl/pgsql 中的任何结果集,那么看看这样的东西:

DO $$
cur RECORD;
BEGIN
FOR cur IN SELECT * FROM LIST
//do something with your JSON
END LOOP;
END $$;

关于sql - 从 postgreSQL 中的 JSON 数组获取单个元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36868150/

相关文章:

mysql替换字符串+下一个字符

mysql - 获取我评论过的帖子以及新评论吗?

php - 从二维数组 PHP 中删除某些索引

json - 有没有办法在JSONPath中获取字符串值的子字符串?

sql - 在 INNER JOIN - SQL 中使用 MAX

来自多个表的 SQL 查询

java - 从Java数组中获取前四名最大值

arrays - 生成具有特定比例的随机二进制序列

json - Jenkins:使用声明性语法从 Jenkinsfile 导入外部包

c++ - 从 Qt 中的 Web 服务解析未命名的 JSON 数组