sql – 可以使用LIKE和IN作为WHERE语句吗?
发布时间:2020-12-12 08:51:53 所属栏目:MsSql教程 来源:网络整理
导读:我有一个地名列表,并希望将它们与sql数据库中的记录进行匹配,问题是属性后面有引用号.例如. ‘Ballymena P-4sdf5g’ 是否可以使用IN和LIKE来匹配记录 WHERE dbo.[Places].[Name] IN LIKE('Ballymena%','Banger%') 解决方法 对于这个构造来说,这是一个常见的误
我有一个地名列表,并希望将它们与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 + '%'; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |