首页 > 数据库技术 > 详细

SQLServer中比较末尾带有空格的字符串遇到的坑

时间:2015-09-03 01:48:38      阅读:300      评论:0      收藏:0      [点我收藏+]

最近发现SQLServer中比较字符串的时候 如果字符串末尾是空格 那么SQLServer会无视那些空格直接进行比较 这和程序中平时的字符串判断逻辑不统一

declare @a nvarchar(50);set @a=Nhappycat1988  
declare @b nvarchar(50);set @b=Nhappycat1988   

if(@a = @b)  
    select True as 直接等号比较
else  
    select False as 直接等号比较
    
    
if(@a like @b)  
    select True as like比较
else  
    select False as like比较

以上查询执行后的结果如下

直接等号比较
------
True

(1 行受影响)

like比较
------
False

(1 行受影响)

从上面可以看出 直接等号判断的时候 SQL会无视末尾的空格 但是like却能够正确的比较 虽然用like也是一种方法 不过如果带有%之类的或许会判断错误 不能单单只用like一个判断 不过反正都是要附加一个条件了 有没有什么比like还简单的呢 于是我就想到了用len函数加上字符串长度同时比较 然后就踩了另外一个坑

 

declare @a nvarchar(50);set @a=Nhappycat1988  
declare @b nvarchar(50);set @b=Nhappycat1988   

select len(@a) len of a ,len(@b) len of b ,datalength(@a) datalength of a ,datalength(@b) datalength of b

以上查询执行后的结果如下

len of a    len of b    datalength of a datalength of b
----------- ----------- --------------- ---------------
12          12          24              26

(1 行受影响)

可以看到len函数也是无视末尾空格的 只有用datalength函数才能作为附加的精确判断的依据

查询了MSDN(LEN (Transact-SQL)) 发现len函数的说明是"Returns the number of characters of the specified string expression, excluding trailing blanks." 也就是排除空格比较的 所以要换用datalength

 

于是乎整理出了一些精确判断字符串的方法

declare @a nvarchar(50);set @a=Nhappycat1988  
declare @b nvarchar(50);set @b=Nhappycat1988   


if(@a = @b and datalength(@a)=datalength(@b))  
    select True as 配合datalength比较  
else   
    select False as 配合datalength比较   
    
if(@a = @b and @a like @b and @b like @a)  
    select True as 配合like比较 
else   
    select False as 配合like比较 
    
if(@a + a = @b + a)  
    select True as 末尾补充字符比较  
else   
    select False as 末尾补充字符比较  

以上查询执行后的结果如下

配合datalength比较
--------------
False

(1 行受影响)

配合like比较
--------
False

(1 行受影响)

末尾补充字符比较
--------
False

(1 行受影响)

 

希望能够帮到同样踩坑的朋友

SQLServer中比较末尾带有空格的字符串遇到的坑

原文:http://www.cnblogs.com/happycat1988/p/4779805.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!