psql json操作符合函数

1.json和jsonb操作符

操作符右操作数类型描述例子例子结果
->int获得 JSON 数组元素(索引从 0 开始,负整数结束)“’[{”“a”":"“foo”"},{"“b”":"“bar”"},{"“c”":"“baz”"}]’::json->2"“{”“c”":"“baz”"}"
->text通过键获得 JSON 对象域“’{”“a”": {"“b”":"“foo”"}}’::json->‘a’"“{”“b”":"“foo”"}"
->>int以文本形式获得 JSON 数组元素‘[1,2,3]’::json->>23
->>text以文本形式获得 JSON 对象域“’{”“a”":1,"“b”":2}’::json->>‘b’"2
#>text[]获取在指定路径的 JSON 对象“’{”“a”": {"“b”":{"“c”": ““foo””}}}’::json#>’{a,b}’"“{”“c”": ““foo””}"
#>>text[]以文本形式获取在指定路径的 JSON 对象“’{”“a”":[1,2,3],"“b”":[4,5,6]}’::json#>>’{a,2}’"3

2.额外的jsonb操作符

操作符右操作数类型描述例子
@>jsonb左边的 JSON 值是否包含顶层右边JSON路径/值项?“’{”“a”":1, ““b””:2}’::jsonb @> ‘{"“b”":2}’::jsonb"
<@jsonb左边的JSON路径/值是否包含在顶层右边JSON值中?“’{”“b”":2}’::jsonb <@ ‘{"“a”":1, ““b””:2}’::jsonb"
?text字符串是否作为顶层键值存在于JSON值中?“’{”“a”":1, ““b””:2}’::jsonb ? ‘b’"
?text[]这些数组字符串中的任何一个是否作为顶层键值存在?
?&text[]这些数组字符串是否作为顶层键值存在?“’[”“a”", ““b””]’::jsonb ?& array[‘a’, ‘b’]"
jsonb
-text从左操作数中删除键/值对或字符串元素。基于键值匹配键/值对。“’{”“a”": ““b””}’::jsonb - ‘a’"
-text[]从左操作数中删除多个键/值对或string元素。 键/值对基于其键值进行匹配。“’{”“a”": ““b””, ““c””: ““d””}’::jsonb - ‘{a,c}’::text[]"
-integer删除指定索引的数组元素(负整数结尾)。如果顶层容器不是一个数组,那么抛出错误。“’[”“a”", ““b””]’::jsonb - 1"
#-text[]删除指定路径的域或元素(JSON数组,负整数结尾)“’[”“a”", {"“b”":1}]’::jsonb #- ‘{1,b}’"

3.其他json处理函数

参考文献:
http://www.postgres.cn/docs/10/functions-json.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值