阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

教你如何解决PostgreSQL Array使用中的一些小问题

63次阅读
没有评论

共计 990 个字符,预计需要花费 3 分钟才能阅读完成。

导读 这篇文章主要介绍了解决 PostgreSQL Array 使用中的一些小问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

在 PostgreSQL 中可以使用 Array 数据结构,例如

select array[1,2,3]; 
return {1,2,3}

但是,如果

select array[1,2,3][1]; -- 会报错 
select (select array[1,2,3])[1] -- 可以使用 

那么在用正则匹配函数 regexp_match 就会遇到这样的问题,如

select regexp_match('123-123', '(\d+)-(\d+)'); --return {123, 123}
select regexp_match('123-123', '(\d+)-(\d+)')[1]; -- 报错 

但是,如果你想获取其中一个元素,你就得使用嵌套查询,如

select(select regexp_match('123-123', '(\d+)-(\d+)'))[1]; --return 123

其次,你如果要用 regexp_matches 加上全局搜索,可能会生成多行数据,如

select 'a', array(select regexp_matches('aa-aa', '(aa)+', 'g'));
-- return 2 rows
a {aa}
a {aa}

合并为一行,需要 array 函数

select 'a', array(select regexp_matches('aa-aa', '(aa)+', 'g'));
--return 
a {{aa},{aa}}

取其中的元素

select a, b[1][1] from (select 'a' as a, array(select regexp_matches('aa-aa', '(aa)+', 'g')) as b) as c;
--return 
aa
补充:PostgreSQL 的 array_to_string 功能

开始

用 第二个参数连接数组元素,例:

postgres=# select array_to_string (ARRAY[1,2,3],'##');
 array_to_string 
-----------------
 1##2##3
(1 row)
postgres=#

结束~

以上为个人经验,希望能给大家一个参考。

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-25发表,共计990字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中