当前位置: 移动技术网 > IT编程>数据库>MSSQL > SQL SERVER中LIKE使用变量类型不同输出结果不一致解惑

SQL SERVER中LIKE使用变量类型不同输出结果不一致解惑

2018年05月22日  | 移动技术网IT编程  | 我要评论

灵龟论坛,网络红人吴大维,微总汇

一同事在写脚本时,遇到一个关于LIKE里面使用不同的变量类型导致查询结果不一致的问题,因为这个问题被不同的人问过好几次,索性总结一下,免得每次都要解释一遍,直接丢一篇博客岂不是更方便!其实看似有点让人不解的现象背后实质跟数据类型的实现有关。

 

下面我们构造这样一个类似的简单案例。如下所

 

CREATE TABLE TEST
(ID        INT IDENTITY(1,1),
 NAME    VARCHAR(32)
)
 
INSERT INTO dbo.test
SELECT 'abc32'
 
INSERT INTO dbo.test
SELECT 'abd32'
 
INSERT INTO dbo.test
SELECT 'abe32' 
 
 
 
 
DECLARE @name  VARCHAR(32);
SET @name='ab%';
SELECT * FROM TEST WHERE NAME LIKE @name;
 
 
DECLARE @name1 CHAR(32);
SET @name1='ab%';
SELECT * FROM dbo.TEST WHERE NAME LIKE @name1;

 

 

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网