PostgreSQL 是一种功能非常齐全关系型数据库,由加州大学计算机系开发
PostgreSQL 开源协议是类 BSD 的自有协议 ,这是一种非常友好的协议,不论是商用还是自用,或者修改代码再起个名拿来卖钱,都没有任何风险
PostgreSQL 支持的数据类型非常多,除了常用的,还有
枚举类型
,几何类型
,UUID类型
,json类型
,数组类型
等,其中数组类型
也是本篇文章的目的,介绍其中数组类型的使用PostgreSQL 成立时对标的数据库是
Oracle
数据库,所有 PostgreSQL 的功能和性能是非常强的。PostgreSQL 对复杂 SQL 的执行,要好于 MySql
..................
还有很多的特性,这里只简单的写几个,上面的几个特点也是我非常在意的,之所 www.helloworld.net
此次改版把 Mysql 换成了 PostgreSQL , 就是有这些原因。
之前很多人问过,hellworld开发者社区
改版用到了哪些技术栈,其中之一,就是把 Mysql
换成了 PostgreSQL
在改版的过程中,所有的表全部重新设计,这对于后端来说,是一个极其需要勇气的决定,好在我们坚持下来了
在改的过程中,其中有这样一个场景:
一篇博客,有多个标签 ,比如 一个博客,有多线程
, 并发
, 线程池
这三个标签
对于这样的需求,我们可以分析一下
- 一篇博客,有多个标签
- 一个标签,也可有对应多篇博客
这样就形成了 多对多
的关系,建表的话,就会有一张关联表,大部分会想到这样建表
博客表: blog
标签表: tag
标签博客表: tag_blog
其中各表的字段,如下(简单起见,只列出最少的列):
blog
表:
- id 数字类型,博客的 id, 自增长的主键
- title 字符串类型,博客的标题
tag
表:
- id 数字类型,标签的 id , 自增长的主键
- name 字符串类型,标签的名字
tag_blog
:
- id 数字类型, 自增长的主键
- tag_id 标签 id (对应 tag 表中的 id)
- blog_id 博客 id (对应 blog 表中的 id)
上面这个博客标签需求,需要 3 张表,我们知道,PostgreSQL 的列的类型是支持数组类型
的
我们是不是可以优化一下上面的需求,把 3 张表变成 1 张表
只保留一张 blog 表,在 blog 表中增加一列 tags , 类似就是 text[ ]
新的博客表字段如下:
blog
表:
- id 数字类型 (bigint),博客的 id, 自增长的主键
- title 字符串类型 (text),博客的标题
- tags 字符串数组类型 (text [] )
为了方便大家测试,建表 SQL 如下
CREATE TABLE IF NOT EXISTS public.blog
(
id bigint NOT NULL DEFAULT nextval('blog_id_seq'::regclass),
title text COLLATE pg_catalog."default",
tags text[] COLLATE pg_catalog."default",
CONSTRAINT blog_pkey PRIMARY KEY (id)
)
TABLESPACE pg_default;
ALTER TABLE IF EXISTS public.blog
OWNER to postgres;
下面我们针对 tags 字段作一些基本操作
数组类型的基本操作
1 查询
现在表中没有数据,我们查询一下看看
select * from blog
结果如下:
2 插入数据
插入一条记录,标题是 www.helloworld.net
, 对应的标签有 3 个,分别是 helloworld
, 技术
, 社区
insert into blog (title,tags) values('www.helloworld.net','{"helloworld","技术","社区"}')
再次查询
select * from blog
结果如下:
可以看到,已经有了一条数据了,tags 数组里面有 3 个元素,分别是 helloworld
, 技术
, 社区
我们再次插入两条数据,方便我们测试
insert into blog (title,tags) values('www.juejin.im','{"掘金","技术","开发者"}');
insert into blog (title,tags) values('www.oschina.net','{"开源中国","oschina","开源"}');