我无法理解为什么会得到以下结果:
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 时没有(可选)大小,为什么字符串比较会失败?
答案如下:http://sqlfiddle.com/#!6/d41d8/4737 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. 您应该始终明确指定大小。
要改掉的坏习惯:声明不带(长度)的 VARCHAR https://sqlblog.org/2009/10/09/bad-habits-to-kick-declaring-varchar-without-length
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)