上面是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’) ;