sql server的奇怪行为

时间:2009-04-16 08:55:32

标签: sql-server sql

我的数据库中有以下表格结构

ID               Name
--------------------------
ID_1             Name1

ID1              Name2

执行以下查询时

SELECT * FROM tblNames
WHERE ID LIKE '_1'

我选择了两个记录......

任何建议如何摆脱它?

4 个答案:

答案 0 :(得分:5)

下划线(_)是LIKE表达式中与单个字符匹配的特殊字符。

要匹配实际的下划线,您需要将其转义:

select * from tblNames where id like '%\_1' escape '\'

这里我告诉SQL Server将反斜杠视为转义字符,并使用它来转义下划线。

或者,您可以将下划线表示为包含单个字符的字符范围 - 在这种情况下,它将按字面解释:

select * from tblNames where id like '%[_]1'

哪一点更简洁。

参考:MSDN

答案 1 :(得分:2)

LIKE operator

快速:_是一个匹配任何内容的通配符。

SELECT * FROM tblNames
WHERE ID LIKE '\_1' ESCAPE '\'

答案 2 :(得分:0)

SELECT * FROM tblNames
WHERE ID LIKE '[_]1'

答案 3 :(得分:0)

下划线字符是like运算符的通配符,它​​匹配任何一个字符。在您的情况下,模式'_1'匹配数据中的'_1'和'D1'。

要在模式中使用文字下划线字符,您需要在其周围放置括号,使其成为仅包含一个字符的字符范围:

SELECT * FROM tblNames
WHERE ID LIKE '[_]1'