Sql语句with =with但LIKE没有修复此问题吗?
以下是确切的代码:
create table zSyn (xField nvarchar(255));
insert into zSyn(xField)
select 'DEVCON 5 Minute Epoxy amber [1:1]';
--Works and returns 1 row:
select * from zSyn
where xField = 'DEVCON 5 Minute Epoxy amber [1:1]';
--Does NOT return any rows:
select * from zSyn
where xField like '%' + 'DEVCON 5 Minute Epoxy amber [1:1]' + '%'发布于 2019-07-07 15:33:25
你需要逃离[]
select * from zSyn
where xField like ('%' + 'DEVCON 5 Minute Epoxy amber ![1:1!]' + '%') ESCAPE '!';发布于 2019-07-07 16:14:46
问题是方形大括号表示Server like中的字符类。一种方法是使用escape。以下是另外两种选择:
xField like '%' + 'DEVCON 5 Minute Epoxy amber [[]1:1]' + '%'
xField like '%' + 'DEVCON 5 Minute Epoxy amber _1:1_' + '%'第二个字符将匹配任何字符,包括一个方括号。就你的目的而言,这可能没问题。
发布于 2019-07-07 15:48:15
如果要避免转义字符串的需要,另一个选择是使用charindex()
示例
Select *
From zSyn
Where charindex('DEVCON 5 Minute Epoxy amber [1:1]',xField)>0https://stackoverflow.com/questions/56923562
复制相似问题