PostgreSQL 操作JSON类型

PostgreSQL 操作JSON类型

1.json和jsonb的操作符

操作符右操作数类型描述示例结果
->int获取JSON数组元素(索引从0开始)select ‘[{“a”:“foo”},{“b”:“bar”},{“c”:“baz”}]’::json->2;{“c”:“baz”}
->text通过键获取值select ‘{“a”: {“b”:“foo”}}’::json->‘a’;{“b”:“foo”}
->>int获取JSON数组元素为 textselect ‘[1,2,3]’::json->>2;3
->>text通过键获取值为textselect ‘{“a”:1,“b”:2}’::json->>‘b’;2
#>text[]在指定的路径获取JSON对象select ‘{“a”: {“b”:{“c”: “foo”}}}’::json#>’{a,b}’;{“c”: “foo”}
#>>text[]在指定的路径获取JSON对象为 textselect ‘{“a”:[1,2,3],“b”:[4,5,6]}’::json#>>’{a,2}’;3

2.jsonb额外操作符

操作符右操作数类型描述示例结果
@>jsonb左侧json最上层的值是否包含右边json对象select ‘{“a”:{“b”:2}}’::jsonb @> ‘{“b”:2}’::jsonb;
select ‘{“a”:1, “b”:2}’::jsonb @> ‘{“b”:2}’::jsonb;
f
t
<@jsonb左侧json对象是否包含于右侧json最上层的值内select ‘{“b”:2}’::jsonb <@ ‘{“a”:1, “b”:2}’::jsonb;t
?texttext是否作为左侧Json对象最上层的键select ‘{“a”:1, “b”:2}’::jsonb ? ‘b’;t
?|text[]text[]中的任一元素是否作为左侧Json对象最上层的键select ‘{“a”:1, “b”:2, “c”:3}’::jsonb ?| array[‘b’, ‘c’];t
?&text[]text[]中的所有元素是否作为左侧Json对象最上层的键select ‘[“a”, “b”]’::jsonb ?& array[‘a’, ‘b’];t
||jsonb连接两个json对象,组成一个新的json对象select ‘[“a”, “b”]’::jsonb || ‘[“c”, “d”]’::jsonb;[“a”, “b”, “c”, “d”]
-text删除左侧json对象中键为text的键值对select ‘{“a”: “b”}’::jsonb - ‘a’;{}
-integer删除数组指定索引处的元素,如果索引值为负数,则从右边计算索引值。如果最上层容器内不是数组,则抛出错误。select ‘[“a”, “b”]’::jsonb - 1;[“a”]
#-text[]删除指定路径下的域或元素(如果是json数组,且整数值是负的,则索引值从右边算起)select ‘[“a”, {“b”:1}]’::jsonb #- ‘{1,b}’;[“a”, {}]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值