PostgreSQL kv(jsonb)存储

项目过程中,存储kv的时候,很多时候会选择redis进行存储,实际用PG也一样可以存储kv,而且查询速度并不慢。

下面可以看看PG存储kv以及其性能

测试如下:

sql 复制代码
test=# select version();
                                                version
--------------------------------------------------------------------------------------------------------
 PostgreSQL 17.4 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 8.5.0 20210514 (Red Hat 8.5.0-4), 64-bit


test=# create table my_table(id int primary key ,data jsonb);
CREATE TABLE

test=# insert into my_table select id,json_build_object(uuid_generate_v4(),uuid_generate_v4(),uuid_generate_v4(),uuid_generate_v4())::jsonb from generate_series(1,10000000) as id;
INSERT 0 10000000
时间:303390.556 ms (05:03.391)
test=# show work_mem;
 work_mem
----------
 4MB
(1 行记录)


时间:0.658 ms
test=# set work_mem='1024MB';
SET
时间:1.108 ms
test=# create index on my_table using gin(data);
CREATE INDEX
时间:227782.340 ms (03:47.782)

est=# select * from my_table where data @> json_build_object('145446c7-1638-4645-8e29-99be69b818cd','0f02d973-2af3-44ba-99ec-1d0384cffb9e')::jsonb;
 id | data
----+------
(0 行记录)


时间:2.081 ms

test=# select * from my_table where data @> json_build_object('a12acfc4-c7ea-4966-a61b-f6e4a6a94ded','ca49b55b-fb07-4491-a396-7b1d46056ffa')::jsonb;
   id    |                                                                               data
---------+------------------------------------------------------------------------------------------------------------------------------------------------------------------
 3400000 | {"76a87307-035a-4bea-81cb-d6e7e2fb5661": "9284780b-4f06-4812-9db7-ca8801f90f83", "a12acfc4-c7ea-4966-a61b-f6e4a6a94ded": "ca49b55b-fb07-4491-a396-7b1d46056ffa"}
(1 行记录)


时间:1.392 ms

从测试数据上看,搜索某个key和value,几乎是毫秒级别的。

相关推荐
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再5 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest5 天前
数据库SQL学习
数据库·sql
jnrjian5 天前
ORA-01017 查找机器名 用户名 以及library cache lock 参数含义
数据库·oracle