PostgreSQL 数组类型
PostgreSQL 支持表的字段使用定长或可变长度的一维或多维数组,数组的类型可以是任何数据库内建的类型、用户自定义的类型、枚举类型,
以及组合类型。但目前还不支持 domain 类型。
数组类型的定义就是通过在数组元素类型名后面附加中括号 [] 来实现的,中括号中可以给一个长度数字,也可以不给,
定义指定多维数组的维度也是没有意义的,数组的维度是根据实际插入的数据来确定的,如下两个语句意义是一样的:
CREATE TABLE test1 (id int, col1 int[], col2 int[], col3 text[][]); CREATE TABLE test2 (id int, col1 int[], col2 int[], col3 text[]);
如何输入数组值
可以使用 ARRAY 构造器语法输入数据,一个数组构造器是一个表达式,它从自身的成员上构造一个数组值。
一个简单的数组构造器由关键字 ARRAY、[、一个或多个表示数组元素值的表达式(用逗号分隔)、] 组成
INSERT INTO test values(, ARRAY['os', 'dba']); INSERT INTO test values(, ARRAY['os"dba', '123"456']); INSERT INTO test values(, ARRAY['os''dba', '''']); // 多维数组,在向多维数组插入值时,各个维度的元素个数必须相同,否则会报错
INSERT INTO test values(, ARRAY[['os', 'dba'],['dba', 'os']]);
访问数组
默认情况下,数组的下标是从 1 开始的,但也可以指定下标的开始值,如下:
CREATE TABLE test02 (id int[]);
INSERT INTO test02 values('[2:4] = {1, 2, 3}');
SELECT id[], id[], id[] FROM test02;
指定上下标的格式为:
'[下标:上标] = [元素值1,元素值2,元素值3,...]'
可以使用数组的切片,如下所示:
SELECT id, col[:] FROM test02;
数组的操作符

数组类型支持一些集合关系的操作符,如下所示:
@> 包含
ARRAY[1, 2, 3] @> ARRAY[1, 2]
结果:t
ARRAY[1, 2, 3] @> ARRAY[1, 4]
结果:f
ARRAY[1, 2, 3] @> ARRAY[2, 1]
结果:t
ARRAY[[1, 2, 3]] @> ARRAY[[1, 2], [2, 3]]
结果:t
<@ 被包含于
ARRAY[1, 2] <@ ARRAY[1, 2, 3]
结果:t
ARRAY[2, 1] <@ ARRAY[1, 2, 3]
结果:t
ARRAY[1, 4] <@ ARRAY[1, 2, 3]
结果:t
ARRAY[[1, 2], [2, 4]] <@ ARRAY[1, 2, 3]
结果:f
&& 重叠,是否有共同元素
ARRAY[1, 2, 3] && ARRAY[3, 4]
结果:t
ARRAY[[1, 2], [3, 4]] && ARRAY[4, 5]
结果:t
ARRAY[1, 2] && ARRAY[3, 4]
结果:f
做集合比较时,不管数组中的元素在哪一维,都可以把它们当作集合中的一个元素,而与数组的维度没有关系。
连接操作符 “||”
同维度的数组与数组连接
ARRAY[1, 2] || ARRAY[3, 4]
结果:{1,2,3,4}
ARRAY[1, 2] || ARRAY[2, 3]
结果:{1,2,2,3}
不同维度的数组与数组连接
ARRAY[1, 2] || ARRAY[[3, 4], [5, 6]]
结果:{{1, 2}, {3, 4}, {5, 6}}
元素与数组之间的连接
1 || ARRAY[2, 3]
结果:{1, 2, 3}
ARRAY[2, 3] || 1
结果:{2, 3, 1}
1 || ARRAY[[2, 3]]
结果:报错
数组的函数
array_cat(anyarray, anyarray)
连接两个数组,返回新数组
示例:array_cat(ARRAY[1, 2], ARRAY[3, 4]) 结果:{1, 2, 3, 4}
array_cat(ARRAY[[1, 2]], ARRAY[3, 4]) 结果:{{1, 2}, {3, 4}}
array_cat(ARRAY[[1, 2]], ARRAY[[3, 4]]) 结果:{{1, 2}, {3, 4}}
array_ndims(anyarray)
返回数组的维度,返回值类型为 int
示例:array_ndims(ARRAY[1, 2, 3]) 结果:1
array_ndims(ARRAY[[1, 2, 3]]) 结果:2
array_ndims(ARRAY[[1, 2, 3], [4, 5, 6]]) 结果:2
array_ndims(ARRAY[[[1, 2, 3]]]) 结果:3
array_length(anyarray, int)
返回数组指定维度的长度,维度数是有由第二个参数指定的
示例: array_length(ARRAY[1, 2, 4], 1) 结果:3
array_length(ARRAY[[1, 2], [3, 4], [5, 6]], 1) 结果:3
array_length(ARRAY[[1, 2], [3, 4], [5, 6]], 2) 结果:2
array_lower(anyarray, int)
返回数组的下标
array_upperer(anyarray, int)
返回数组的上标
array_prepend(anyelement, anyarray)
在数组的开头插入一个元素
示例: array_prepend(7, ARRAY[8, 9]) 结果:{7, 8, 9}
array_remove(anyarray, anyelement)
移除数组中为指定值的元素,只支持一维数组
示例: array_remove(ARRAY[1, 2, 3], 2) 结果: {1, 3}
array_remove(ARRAY[1, 2, 3, 2, 1, 2], 2) 结果: {1, 3. 1}
array_replace(anyarray, anyelement, anyelement)
把数组中等于指定值元素的值用另一个指定值替代
示例: array_replace(ARRAY[1, 4, 3], 4, 2) 结果:{1,2,3}
array_to_string(anyarray, text)
使用指定的分隔符(第二个参数) 将数组元素连接为字符串
示例: array_to_string(ARRAY[1,2,3], ',') 结果:'1,2,3'
string_to_array(text, text)
用指定的分隔符分隔的字符串转成数组
示例:string_to_array('1,2,3', ',') 结果:{1, 2, 3}
unnest(anyarray)
把数组变成多行返回
array_agg(字段)
聚合函数
转发请著名出处:https://www.cnblogs.com/ryanzheng/p/9610182.html
PostgreSQL 数组类型的更多相关文章
- PostgreSQL数组类型应用
在使用 awk 脚本:数组是一大利器:在很多场景是用数组能处理. 在 python 中,数据类型list:相当于array类型. 在 Oracle 中,对 array 不够友好,感觉像是鸡肋.但是在 ...
- postgresql —— 数组类型
创建数组 CREATE TABLE sal_emp ( name text, pay_by_quarter integer[] --还可以定义为integer[4]或integer ARRAY[4] ...
- PostgreSQL Array 数组类型与 FreeSql 打出一套【组合拳】
前言 PostgreSQL 是世界公认的功能最强大的开源数据库,除了基础数据类型 int4/int8/varchar/numeric/timestamp 等数据类型,还支持 int4[]/int8[] ...
- mybatis 处理数组类型及使用Json格式保存数据 JsonTypeHandler and ArrayTypeHandler
mybatis 比 ibatis 改进了很多,特别是支持了注解,支持了plugin inteceptor,也给开发者带来了更多的灵活性,相比其他ORM,我还是挺喜欢mybatis的. 闲言碎语不要讲, ...
- java中用spring实现数组类型输出
java 中的几个数组类型 1.Department类 package com.yy.collection; import java.util.List; import java.util.Map; ...
- JS数组类型检测
在强类型语言,数组类型检测是非常容易的事情(typeof就可以解决),而在弱语言JS数据类型就很容易混淆了. JS中常见的数据类型有:number.string.boolean.undefined.f ...
- C语言 数组类型与数组指针类型
//数组类型与数组指针类型 #include<stdio.h> #include<stdlib.h> #include<string.h> void main(){ ...
- delphi 数组类型与数组指针的巧妙利用
{本例通过存取结构, 慢慢引入了数组类型与指针的一些使用方法; 其中六个小例子的测试内容和结果都是一样的. ---------------------------------------------- ...
- delphi 数组类型
数组类型 数组类型定义了一组指定类型的元素序列,在方括号中填入下标值就可访问数组中的元素.定义数组时,方括号也用来指定可能的下标值.例如,下面的代码中定义了一个有 24 个整数的数组:type ...
随机推荐
- 有些其他程序设置为从 Outlook 下载并删除邮件。为防止发生此意外情况,我们将这些邮件放入一个特殊的 POP 文件夹中
最近使用FOXMAIL接收MSN邮件时,发现有一些邮件收取不到,进到WEB页面,页面下方提示“你的邮件位于 POP 文件夹中!有些其他程序设置为从 Outlook 下载并删除邮件.为防止发生此意外情况 ...
- pat乙级1051
当结果中a或者b小于0,大于0.005时,保留两位小数会输出-0.00,但应输出0.00. #include <iostream> #include <math.h> usin ...
- sql常识
1.UNION与UNION ALL的区别UNION去重且排序UNION ALL不去重不排序2.sql语句or与union all的执行效率比较:union all>union> in &g ...
- 理解MVC 框架
前言:很多前端开发者面临着这样的问题,在项目开发中承担的工作越来越多,后端要做的越来越少,需要的技术棧越来越多,经常有人问你个技术是你完全不会的,对自己的职业生涯越来越怀疑.从前认为HTML+CSS+ ...
- 【洛谷3648】[APIO2014] 序列分割(斜率优化DP)
点此看题面 大致题意: 你可以对一个序列进行\(k\)次分割,每次得分为两个块元素和的乘积,求总得分的最大值. 区间\(DPor\)斜率优化\(DP\) 这题目第一眼看上去感觉很明显是区间\(DP\) ...
- 2018.2.3 Centos 的vim好看的主题配置及JDK的安装配置
这里用的是Centos7云服务器的系统 第一步登录 centos7 系统: 通过查看命令 rpm -qa | grep vi 第二步:检测是否已经安装过Vim: 输入命令:rpm -qa|grep v ...
- mac 扫描存活IP段
法一:脚本内容 MacdeMacBook-Pro:~ root# cat ping-ttl.sh #!/bin/bash [ $UID -ne 0 ]&&{ echo "Pl ...
- python_65_生成器1
# map()函数 # map()是 Python 内置的高阶函数,它接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的 list 并返回. # 例 ...
- pandas 代码
def get_train_data(): df = pd.read_csv('data/train.csv', encoding='utf_8') # df1 = pd.read_csv('data ...
- Bootstrap历练实例:警告框(Alert)插件事件
事件 下表列出了警告框(Alert)插件中要用到的事件.这些事件可在函数中当钩子使用. 事件 描述 实例 close.bs.alert 当调用 close 实例方法时立即触发该事件. $('#myal ...