sql – 可以使用LIKE和IN作为WHERE语句吗?

前端之家收集整理的这篇文章主要介绍了sql – 可以使用LIKE和IN作为WHERE语句吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个地名列表,并希望将它们与sql数据库中的记录进行匹配,问题是属性后面有引用号.例如. ‘Ballymena P-4sdf5g’
是否可以使用IN和LIKE来匹配记录
WHERE dbo.[Places].[Name] IN LIKE('Ballymena%','Banger%')

解决方法

对于这个构造来说,这是一个常见的误解
b IN (x,y,z)

那个(x,z)代表一个集合.它不是.

相反,它只是语法糖

(b = x OR b = y OR b = z)

sql只有一个数据结构:表.如果要将搜索文本值作为集合查询,请将其放入表中.您可以在JOIN条件下使用LIKE将搜索文本表加入您的Places表.

WITH Places (Name)
     AS
     (
      SELECT Name
        FROM (
              VALUES ('Ballymeade Country Club'),('Ballymena Candles'),('Bangers & Mash Cafe'),('Bangebis')
             ) AS Places (Name)
     ),SearchText (search_text)
     AS
     (
      SELECT search_text
        FROM (
              VALUES ('Ballymena'),('Banger')
             ) AS SearchText (search_text)
     )
SELECT * 
  FROM Places AS P1
       LEFT OUTER JOIN SearchText AS S1
          ON P1.Name LIKE S1.search_text + '%';

猜你在找的MsSQL相关文章