我有一个地名列表,并希望将它们与sql数据库中的记录进行匹配,问题是属性后面有引用号.例如. ‘Ballymena P-4sdf5g’
是否可以使用IN和LIKE来匹配记录
是否可以使用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 + '%';