明明字符串完全一样,为什么条件不执行?

在sqlserver中检查字符串的时候,切忌使用select输出的表格中数据(这些数据有时会误导你);

如下面脚本:

DECLARE @tmpVar1 VARCHAR(200)='55057400@WARM ORANGE 011 SP09	011'
DECLARE @tmpVar2 VARCHAR(200)='55057400@WARM ORANGE 011 SP09 011'

SELECT @tmpVar1 AS 'var1',@tmpVar2 AS 'var2'

输出结果:

从上面两个单元格中复制出来字符串检查时,如下:

/*
55057400@WARM ORANGE 011 SP09 011
55057400@WARM ORANGE 011 SP09 011
*/

完全一样,看不出来不同呀!

但是将上面脚本改为用print输出后,再看:

DECLARE @tmpVar1 VARCHAR(200)='55057400@WARM ORANGE 011 SP09	011'
DECLARE @tmpVar2 VARCHAR(200)='55057400@WARM ORANGE 011 SP09 011'

SELECT @tmpVar1 AS 'var1',@tmpVar2 AS 'var2'
/*
55057400@WARM ORANGE 011 SP09 011
55057400@WARM ORANGE 011 SP09 011
*/

PRINT @tmpVar1
PRINT @tmpVar2

能够明显看到两个字符串中的不同,上面的是一个tab字符,而下面的字串中是一个空格字符;

结论:

在SQLSERVER中检查字符串时,在看不出来不同的情况下,请使用Print进行输出查看

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值