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,几乎是毫秒级别的。

相关推荐
vivo互联网技术3 小时前
从 10 分钟到 1 秒:ES 深度分页任意跳页的三轮优化实战
服务器·数据库·redis·elasticsearch·深度分页
倔强的石头_18 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB20 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
jiayou642 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE3 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr3 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩4 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3505 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3505 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3505 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库