postgresql 查询:查询是否在该列:一个字符串以“|”分割的列

 上面是section 表中的link_laneid 的字段描述。

需求是:查询一个值是否在link_laneId 中存在(注意这个值是个复合类型,以“|”分割的字符串)。

sql语句:

select * 
from section 
where 162243 = any((string_to_array(link_laneid,'|'))::int[])

 说明

  • string_to_array:该函数在postgresql中是将字符串转为数组的格式。

‘A,1,B,人,汽车’这个字符串根据逗号分隔符转化为数组格式:

select string_to_array('A,1,B,人,汽车', ',')
  • regexp_split_to_array 是将分隔的数据转成数组

       例如:regexp_split_to_array('被分割的字符串',  '的')

SELECT array from regexp_split_to_array('汽车,星越L,领克09,领克01,领克08,领克03+', ',') 
  • in和any的用法一样。但是any取的是一个set,括号里是数组(必须是实际的数组类型);in取的是一个集合,是逗号分隔的值列表。
SELECT ‘1’ = ANY (ARRAY[‘1’, ‘2’]) ;
SELECT ‘1’ in (‘1’,‘2’) ;

你可能感兴趣的:(sql,数据库)