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