Postgresql数据类型-数组类型

PostgreSQL支持一维数组和多维数组,常用的数组类型为数字类型数组和字符型数组,也支持枚举类型、复合类型数组。

数组类型定义

先来看看数组类型的定义,创建表时在字段数据类型后面加方括号“[]”即可定义数组数据类型,如下所示:

        CREATE TABLE test_array1 (id          integer,array_i     integer[],array_t     text[]);

以上integer[]表示integer类型一维数组,text[]表示text类型一维数组。

数组类型值输入

数组类型的插入有两种方式,第一种方式使用花括号方式,如下所示:

        '{ val1 delim val2 delim ... }'

将数组元素值用花括号“{}”包围并用delim分隔符分开,数组元素值可以用双引号引用,delim分隔符通常为逗号,如下所示:

        mydb=> SELECT '{1,2,3}';?column?----------{1,2,3}(1 row)往表test_array1中插入一条记录的代码如下所示:mydb=> INSERT INTO test_array1(id, array_i, array_t)VALUES (1, '{1,2,3}', '{"a", "b", "c"}');INSERT 0 1

数组类型插入的第二种方式为使用ARRAY关键字,例如:

        mydb=> SELECT array[1,2,3];array---------{1,2,3}(1 row)

往test_array2表中插入另一条记录,代码如下所示:

        mydb=> INSERT INTO test_array1(id, array_i, array_t)VALUES (2, array[4,5,6], array['d', 'e', 'f']);INSERT 0 1

表test_array2的数据如下所示:

        mydb=> SELECT * FROM test_array1;id | array_i | array_t-------+---------+---------1 | {1,2,3} | {a, b, c}2 | {4,5,6} | {d, e, f}(2 rows)

查询数组元素

如果想查询数组所有元素值,只需查询数组字段名称即可,如下所示:

        mydb=> SELECT array_i FROM test_array1 WHERE id=1;array_i---------{1,2,3}(1 row)

数组元素的引用通过方括号“[]”方式,数据下标写在方括号内,编号范围为1到n, n为数组长度,如下所示:

        mydb=> SELECT array_i[1], array_t[3] FROM test_array1 WHERE id=1;array_i | array_t------------+---------1 | c(1 row)

数组元素的追加、删除、更新

PostgreSQL数组类型支持数组元素的追加、删除与更新操作,数组元素的追加使用array_append函数,用法如下所示:

        array_append(anyarray, anyelement)

array_append函数向数组末端追加一个元素,如下所示:

        mydb=> SELECT array_append(array[1,2,3],4);array_append--------------{1,2,3,4}(1 row)

数据元素追加到数组也可以使用操作符||,如下所示:

        mydb=> SELECT array[1,2,3] || 4;?column?-----------{1,2,3,4}(1 row)

数组元素的删除使用array_remove函数,array_remove函数用法如下所示:

        array_remove(anyarray, anyelement)

array_remove函数将移除数组中值等于给定值的所有数组元素,如下所示:

        mydb=> SELECT array[1,2,2,3], array_remove(array[1,2,2,3],2);array   | array_remove------------+--------------{1,2,2,3} | {1,3}(1 row)

数组元素的修改代码如下所示:

        mydb=> UPDATE test_array1 SET array_i[3]=4 WHERE id=1 ;UPDATE 1

整个数组也能被更新,如下所示:

        mydb=> UPDATE test_array1 SET array_i=array[7,8,9] WHERE id=1;UPDATE 1

数组操作符

PostgreSQL数组元素支持丰富操作符,如表所示。

PostgreSQL支持丰富的数组函数,给数组添加元素或删除元素,如下所示:

        mydb=> SELECT array_append(array[1,2],3), array_remove(array[1,2],2);array_append | array_remove-----------------+--------------{1,2,3}      | {1}(1 row)

 获取数组维度,如下所示:

        mydb=> SELECT array_ndims(array[1,2]);array_ndims-------------1(1 row)

获取数组长度,如下所示:

        mydb=> SELECT array_length(array[1,2],1);array_length--------------2(1 row)

返回数组中某个数组元素第一次出现的位置,如下所示:

        mydb=> SELECT array_position(array['a', 'b', 'c', 'd'], 'd');array_position----------------4(1 row)

数组元素替换可使用函数array_replace,语法如下:

        array_replace(anyarray, anyelement, anyelement)

函数返回值类型为anyarray,使用第二个anyelement替换数组中的相同数组元素,如下所示:

        mydb=> SELECT array_replace(array[1,2,5,4],5,10);array_replace---------------{1,2,10,4}(1 row)

将数组元素输出到字符串,可以使用array_to_string函数,语法如下:

        atray_to_string(anyarray, text [, text])

函数返回值类型为text,第一个text参数指分隔符,第二个text表示将值为NULL的元素使用这个字符串替换,示例如下:

        mydb=> SELECT array_to_string(array[1,2, null,3], ', ', '10');array_to_string-----------------1,2,10,3(1 row)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/170699.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVS低代码表单自定义按钮的使用说明和操作示例

在普通的表单设计中,虽然自带的【提交】、【重置】、【取消】按钮可以满足基本操作需求,但在面对更多复杂的业务场景时,这些按钮的显示控制就显得有些力不从心。为了更好地满足用户在表单操作过程中的个性化需求,JVS低代码推出了表…

【03】Istio Gateway示例配置

3.1 开放kiali至集群外部 首先将istio-inressateway暴露集群外部; 在node02的ens33网卡上面有多余的ip地址,将该地址绑定在igressgateway的svc 上面。 kubectl edit svc istio-ingressgateway -n istio-system定义kiali的ingress gateway的资源配置清单 apiVersion:…

阿里云服务器搭建sql 服务

阿里云搭建mysql服务 环境准备 系统镜像 ubuntu 如果买点的实例不是ubuntu 系统镜像,需要停止服务之后,更改镜像 更新 apt-get : 更新apt-get: sudo apt-get update 如果没有出现:apt-get 找不到此命令的错误,可能是…

【KVM-4】硬件虚拟化技术(详)

前言 大家好,我是秋意零。 经过前面章节的介绍,已经知道KVM虚拟化必须依赖于硬件辅助的虚拟化技术,本节就来介绍一下硬件虚拟化技术。 👿 简介 🏠 个人主页: 秋意零🔥 账号:全平…

OpenCV:图像噪点消除与滤波算法

人工智能的学习之路非常漫长,不少人因为学习路线不对或者学习内容不够专业而举步难行。不过别担心,我为大家整理了一份600多G的学习资源,基本上涵盖了人工智能学习的所有内容。点击下方链接,0元进群领取学习资源,让你的学习之路更加顺畅!记得…

2023NewStarCTF

目录 一、阳光开朗大男孩 二、大怨种 三、2-分析 四、键盘侠 五、滴滴滴 六、Include? 七、medium_sql 八、POP Gadget 九、OtenkiGirl 一、阳光开朗大男孩 1.题目给出了secret.txt和flag.txt两个文件,secret.txt内容如下: 法治自由公正爱国…

网络编程套接字(3)——协议定制 | 序列化与反序列化

文章目录 一.认识“协议”1.协议的概念2.结构化数据的传输3.序列化和反序列化 二. 网络版计算器1.服务端2.协议定制(1) 网络发送和读取的正确理解(2) 协议定制的问题 3.客户端4.代码 三.Json实现序列化反序列化1.简单介绍2.使用 一.认识“协议” 1.协议的概念 协议&#xff0c…

Golang源码分析 | 程序引导过程

环境说明 CentOS Linux release 7.2 (Final) go version go1.16.3 linux/amd64 GNU gdb (GDB) Red Hat Enterprise Linux 7.6.1-80.el7使用gdb查看程序入口 编写一个简单的go程序 // main.go package mainfunc main() {print("Hello world") } 编译go …

STM32——STM32F4系统架构

文章目录 前言STM32F4XX系统架构 前言 本篇文章为STM32F4系列的系统架构,因为最近在学习F4的板子,暂时先更F4的,有需要F1的后续再更新。 主系统由 32 位多层 AHB 总线矩阵构成,可实现以下部分的互连: STM32F4XX系统架…

docker通过nginx代理tomcat-域名重定向

通过昨天的调试,今天做这个域名就简单了, 正常我们访问网站一般都是通过域名比如,www.baidu.com对吧,有人也通过ip,那么这个怎么做呢?物理机windows可以通过域名访问虚拟机linux的nginx代理转向tomcat服务…

web基础和http协议(粗糙版)

服务部署,集训,分布式,数据库,日志系统,等二阶段 web基础和http协议: web的相关基础知识,包括域名 dns解析 网页的概念以及http协议 1.网络当中通信:端口 ip 协议 tcp/ip 传输过程…

postswigger 靶场(CSRF)攻略-- 1.没有防御措施的 CSRF 漏洞

靶场地址: What is CSRF (Cross-site request forgery)? Tutorial & Examples | Web Security Academy (portswigger.net)https://portswigger.net/web-security/csrf 没有防御措施的 CSRF 漏洞 题目中已告知易受攻击的是电子邮件的更改功能,而目…