如何在有分隔符“;”的字符串中搜索整个单词?
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
要搜索 CSV 列表中的字段,一种方法是:
where ';' + mycol + ';' like '%;mri;%'
 
在 DB Fiddle 上演示:
with 
    csv as (select 'Blood work;MRI;ICC' v),
    match as (select 'mri' m union all select 'Blood work' union all select 'Blood')
select csv.v, match.m,
    case when ';' + csv.v + ';' like '%;' + match.m + ';%' 
        then 'match' 
        else 'no match' 
    end matched
from csv
cross join match 
v                  | m          | matched 
:----------------- | :--------- | :-------
Blood work;MRI;ICC | mri        | match   
Blood work;MRI;ICC | Blood work | match   
Blood work;MRI;ICC | Blood      | no match