【数据库】GBase 8s数据库存储json格式数据

这篇博客介绍了如何在MongoDB数据库中创建、插入和查询BSON数据。内容包括使用`bson`数据类型创建表,将JSON字符串插入到数据库,以及通过`bson_extract`函数查询和提取JSON对象及列表中的特定字段值。示例涵盖了从JSON对象中提取地址字段,从嵌套对象中获取数值,以及从JSON列表中选取特定元素的操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

建表

创建一张包含bson(json的二进制数据类型)数据类型的表

-- data为要存储json数据的字段
create table testjson(id int, data bson);

插入json数据

insert into testjson values(1, '{"name": "GBASE", "address": "天津 南开华苑"}'::json);

查询json数据

select data::json from testjson;

查询json指定字段address

select bson_extract(data, "address")::bson::json from testjson;

当指定字段的值是json对象时,从对象中提取指定key的值

-- other的value是json对象
insert into testjson values(2, '{"name": "gbase", "other": {"address": "天津南开", "number": 123456}}'::json);
-- 从other的value中提取number的值
select bson_extract(data, "other.number")::bson::json from testjson;

当指定字段的值是列表时,提取列表中指定位置的元素

-- other的value是列表,列表中的元素是json
insert into testjson values(2, '{"name": "gbase", "other": [{"address": "天津南开", "number": 123456}, {"address": "天津海泰", "number": 88888}]}'::json);
-- 从other的value中提取第二个元素(序号从0开始)的address
select bson_extract(data, "other.1.address")::bson::json from testjson;
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值