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

本文介绍了如何在PostgreSQL数据库中使用`string_to_array`函数将字符串转换为数组,并通过`any`关键字查询link_laneId字段,如A,1,B,人,汽车,以检查特定值是否存在。同时提及了`in`和`any`的区别以及`regexp_split_to_array`的用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值