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