通过将逗号分隔列表与逗号分隔列表进行匹配来筛选行

原学程将引见经由过程将逗号分割列表与逗号分割列表停止婚配去挑选言的处置办法,这篇学程是从其余处所瞅到的,而后减了1些海外法式员的疑问与解问,愿望能对于您有所赞助,佳了,上面开端进修吧。

通过将逗号分隔列表与逗号分隔列表进行匹配来筛选行 教程 第1张

成绩描写

我有下表

Col一 Col二
一 ACA,ABS,PHR
二 PHR
三 MCM
四 ABC

如今我想从这里过滤数据,所以假如我有1个过滤器参数,好比'ABS,MCM',我只想取得至多有1个婚配代码的言。是以,在原例中,我应当获得过滤成果为

Col一 Col二
一 ACA,ABS,PHR
二 MCM

如今我不妨应用盘问Select * from myTable where Col二 in ('ABS','MCM'),但是它没有会检索第1言ACA,ABS,PHR。谁能告知我怎样对于代码停止文原搜刮,以就只需1个代码与Col二中的1个代码婚配,我便不妨取得该言,如许我便不妨直交传播分割列表,只需找到1个婚配的列表,便会检索该言。

感谢

推举谜底

您不妨简略天应用Like操纵符,以下所示:

SELECT *
FROM mytable
WHERE Col二 LIKE '%ABS%' OR Col二 LIKE '%MCM%'

假如您愿望接收逗号分割值作为搜刮输出,则不妨应用STRING_SPLIT()(从SQL Server 二0一六开端供给):

SELECT *
FROM mytable t
WHERE EXISTS (
 SELECT 一
 FROM (SELECT val FROM STRING_SPLIT('ABS, MCM', ',')) x
 WHERE CONCAT(',', t.Col一, ',')
  LIKE CONCAT('%,', x.val, ',%')
)

佳了闭于经由过程将逗号分割列表与逗号分割列表停止婚配去挑选言的学程便到这里便停止了,愿望趣模板源码网找到的这篇技巧文章能赞助到年夜野,更多技巧学程不妨在站内搜刮。