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

相关推荐
Doris_LMS22 分钟前
保姆级别IDEA关联数据库方式、在IDEA中进行数据库的可视化操作(包含图解过程)
java·mysql·postgresql
2301_7930868730 分钟前
Mysql group by
数据库·mysql
jllllyuz1 小时前
Spring中的事务是如何实现的
数据库·sql·spring
wangmengxxw1 小时前
Spring-常用注解
java·数据库·spring·注解
m0_747266091 小时前
contentprovider实验+SQLite数据库的实现
数据库·sqlite
TDengine (老段)2 小时前
TDengine 中 TDgp 中添加机器学习模型
大数据·数据库·算法·机器学习·数据分析·时序数据库·tdengine
网安Ruler2 小时前
Web开发-PHP应用&Cookie脆弱&Session固定&Token唯一&身份验证&数据库通讯
前端·数据库·网络安全·php·渗透·红队
zfoo-framework4 小时前
线上redis的使用
数据库·redis·缓存
典孝赢麻崩乐急5 小时前
Redis学习-----Redis的基本数据类型
数据库·redis·学习
止水编程 water_proof5 小时前
MySQL——事务详解
数据库·mysql