服务器之家

服务器之家 > 正文

PostgreSQL中使用数组改进性能实例代码

时间:2020-05-01 17:27     来源/作者:clia

前言

postgresql支持数组类型,可以是基本类型,也可以是用户自定义的类型。日常中使用数组类型的机会不多,但还是可以了解一下。不像C或JAVA高级语言的数组下标从0开始,postgresql数组下标从1开始,既可以指定长度,也可以不指定长度。且postgresql既支持一维数组,也支持多维数组,但是平时二维数组也就够用了。

本文将给大家介绍PostgreSQL通过数组改进性能的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

PostgreSQL通过数组改进性能

创建一个用户和设备关系映射表,用户的设备ID存放在数组字段里面:

?
1
2
3
4
5
6
CREATE TABLE device.user_devices
(
user_id character varying(32) COLLATE pg_catalog."default" NOT NULL,
device_ids character varying[] COLLATE pg_catalog."default" NOT NULL,
CONSTRAINT user_devices_pkey PRIMARY KEY (user_id)
)

将数据导入表:

?
1
2
3
4
5
6
insert into device.user_devices
 select device_owner, array_agg(device_id)
 from device.device_info
 where device_owner is not null
 and device_owner != ''
 group by device_owner

比较原查询方式和新查询方式的性能:

原查询方式:

PostgreSQL中使用数组改进性能实例代码

新查询方式:

PostgreSQL中使用数组改进性能实例代码

可以发现新查询方式的性能有了巨大的提升!

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。

原文链接:https://yq.aliyun.com/articles/679693

标签:

相关文章

热门资讯

沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意
沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意 2019-07-07
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
超A是什么意思 你好a表达的是什么
超A是什么意思 你好a表达的是什么 2019-06-06
和平精英超高音质怎么修改 和平精英超高音质重启设置方法
和平精英超高音质怎么修改 和平精英超高音质重启设置方法 2019-06-26
返回顶部