SQLServer 中比较末尾带有空格的字符串
最近发现SQLServer中比较字符串的时候 如果字符串末尾是空格 那么SQLServer会无视那些空格直接进行比较 这和程序中平时的字符串判断逻辑不统一 但是,如果字符串前带有空格,SQLServer会正确判断,若要去除字符串前部空格,使用LTrim函数: RTrim和LTrim嵌套使用 RTrim(LTrim(' ?Hi,Good Morning ?')); 返回 ‘ Hi,Good Morning’declare @a nvarchar(50);set @a=N'happycat1988' declare @b nvarchar(50);set @b=N'happycat1988 ' 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=N'happycat1988' declare @b nvarchar(50);set @b=N'happycat1988 ' 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=N'happycat1988' declare @b nvarchar(50);set @b=N'happycat1988 ' 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 行受影响) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- sql-server – 如何从具有动态节点数的XML文件创建SQL表?
- 兼容SQLSERVER、Oracle、MYSQL、SQLITE的超级DBHelper
- 关于SQLServer数据库的问题
- sql – 使用带有Scope_IDENTITY的MERGE INTO
- 如何根据另一个表中的组编写sql语句来计算总计?
- sql – 没有sysadmin权限的OpenRowSet和OpenDataSet
- 使用NotePad++录制宏功能如何快速将sql搜索条件加上前后单引
- .Net在SqlServer中的图片存取技术
- .net+mssql制作抽奖程序思路及源码
- 在SAS中使用PROC SQL查找与给定字符串最多一个字母的字符串