postgresql的数组函数

select array_agg(study_start_dt) from t1 --where study_start_dt is not null
--{2,1,1,1,65681,65685,65687,65690,65692,65694}
--{NULL,NULL,"2020-06-05 14:56:29.066",NULL,"2020-06-04 09:36:49.717","2******}

检索满足条件的study_start_dt,拼成一个array

select (select array_agg(user_pk) from t1) @> array[6,1]						--1
select (select array_agg(''||user_pk) from t1) @> string_to_array('6,1',',')	--2
select (select array_agg(''||user_pk) from t1) @> array['6','1']				--3
select (select string_agg(distinct user_pk||'',',') from t1) like
			 	'%'||array_to_string(array[1,6],'%')||'%'						--4
select (select string_agg(distinct user_pk||'',',') from t1) like 
				'%'||array_to_string(array[6,1],'%')||'%'						--5
--select array[seminar_status_pk,user_pk,seminars_pk] && array[4,3] from t1  	--6

这5个语句都用来完成检索user_pk拼成一个array后是否包含6和1(任意顺序)。
4和5使用字符串拼接+模糊查询,会遇到顺序问题,预计效率较低。6的&&是取交集。

select array[1,2,null] @> array[1]				--true
select array[1,2,null] @> array[null,1]			--false
select array[c1,c2,c3,null,null],array[c1,c2,c3,null,null] @> array[1,null] from t1   	--3
select array[c1,c2,c3,null,null],array[c1,c2,c3,null,null] @> array[1,3] from t1		--4
select * from t1 where array[c1,c2,c3,null] @> array[1]									--5

3和4把返回的字段的值拼接成array,5返回这些字段中有1这个值的数据

select 5=any(array[3,4,5])				--true
--select any(array[3,4,5])=5			--error

判断array里是否含有某一个值,可以用any。注意=号左边应该放常量值,否则可能报错。

--like也有顺序,如下
select '123' like '%'			--true
select '%' like  '123' 		--false
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值