我无法理解为什么我会得到以下结果:
declare @myVar1 varchar = 'Friday'
declare @myVar2 varchar(10) = 'Friday'
select
case when @myVar1 = 'Friday' then 'yes' else 'no' end as test1,
case when @myVar2 = 'Friday' then 'yes' else 'no' end as test2,
case when @myVar1 = @myVar2 then 'yes' else 'no' end as test3
我得到的是:
test1: no
test2: yes
test3: no
如果在没有(可选)大小的情况下声明varchar,为什么字符串比较会失败?
答案 0 :(得分:6)
以下是答案:http://sqlfiddle.com/#!6/d41d8/4737
declare @myVar1 varchar = 'Friday'
declare @myVar2 varchar(10) = 'Friday'
select len(@myVar1)as len1,
len(@myVar2)as len2
结果是:
LEN1 LEN2
1 6
因此,如果您没有为varchar
指定大小,SQL Server将为您执行此操作。在这种情况下1.您应该始终明确指定大小。