Sql 知识积累2023.10月

Sql 知识积累2023.10月

Postgrel Sql中JSON

  • Postgrel Version: 9.6
  • 官方文档:http://postgres.cn/docs/9.6/functions-json.html#FUNCTIONS-JSON-CREATION-TABLE

JSON与JSONB

  • 相同点
    • 都用来存储json数据
  • 不同点
    • 存储方式不同:json是以文本格式进行存储的;jsonb是以二进制格式进行存储的。
    • 写入速度不同:json > jsonb (因为把json解析之后再进行存储,所以jsonb多了解析的过程)
    • 条件查询速度不同:json < jsonb (因为每次读取json都需要进行解析,多了解析的过程)
    • json格式上的不同:json原样进行存储,会保留空格等不影响含义的字符;jsonb会解析之后进行存储,所以不会保留空格等字符,且json中key不能重复,如重复保留最后一个值。
  • 使用建议
    • 如果你的应用只是需要对json进行保存和读取,则建议使用json
    • 如果你的应用需要在PostgreSQL中做比较多的json值操作,或者在json字段上使用索引时,应该使用jsonb

Postgrel Sql中JSON操作

jsonjsonb 操作符

操作符右操作数类型描述例子例子结果
->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

常用的JSON创建操作

JSON创建函数

to_json(anyelement) to_jsonb(anyelement)把值返回为json或者jsonb。数组和组合被(递归地)转换成数组和对象;否则, 如果有从该类型到json的投影,将使用该投影函数来执行转换; 否则将产生一个标量值。对任何一个数值、布尔量或空值的标量类型, 将使用其文本表达,以这样一种方式使其成为有效的json或者jsonb值。to_json('Fred said "Hi."'::text)"Fred said \"Hi.\""
--- 查询数据转换为json格式
select to_json(epm.*) from event_process_main epm limit 5 

字符串函数和操作符:

函数返回类型描述例子结果
string || stringtext字串连接‘Post’ || ‘greSQL’PostgreSQL
substring(string [from int] [for int])text抽取子字串substring(‘Thomas’ from 2 for 3)hom
left(str, length)\right(str, length)text获取字符串左、右开始截取select left(‘hello world’, 3)hel
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值