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

一同事在写脚本时,遇到一个关于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;

 

 

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐