首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Sql语句with =工作,但LIKE不工作

Sql语句with =工作,但LIKE不工作
EN

Stack Overflow用户
提问于 2019-07-07 15:30:14
回答 4查看 66关注 0票数 1

Sql语句with =with但LIKE没有修复此问题吗?

以下是确切的代码:

代码语言:javascript
复制
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]' + '%'
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2019-07-07 15:33:25

你需要逃离[]

代码语言:javascript
复制
select * from zSyn
where xField like ('%' + 'DEVCON 5 Minute Epoxy amber ![1:1!]' + '%') ESCAPE '!';

db<>fiddle demo

票数 6
EN

Stack Overflow用户

发布于 2019-07-07 16:14:46

问题是方形大括号表示Server like中的字符类。一种方法是使用escape。以下是另外两种选择:

代码语言:javascript
复制
xField like '%' + 'DEVCON 5 Minute Epoxy amber [[]1:1]' + '%'
xField like '%' + 'DEVCON 5 Minute Epoxy amber _1:1_' + '%'

第二个字符将匹配任何字符,包括一个方括号。就你的目的而言,这可能没问题。

票数 2
EN

Stack Overflow用户

发布于 2019-07-07 15:48:15

如果要避免转义字符串的需要,另一个选择是使用charindex()

示例

代码语言:javascript
复制
Select * 
 From  zSyn
 Where charindex('DEVCON 5 Minute Epoxy amber [1:1]',xField)>0
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56923562

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档