详解SQL Server 比较带有尾随空格的字符串

2024-05-12 08:32

本文主要是介绍详解SQL Server 比较带有尾随空格的字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、问题描述

[sql]  view plain copy print ?
  1. declare @a varchar(10);set @a='maco '  
  2. declare @b varchar(10);set @b='maco'  
  3. if(@a=@b)  
  4.     select '@a与@b相等'  
  5. else  
  6.     select '@a与@b不相等'  
  7. --运行结果  
  8. /*  
  9. @a与@b相等  
  10. */  

@a后面有尾随空格,@b后面没有,但是为什么他们相等呢?

 

2、问题解析

2.1 有尾随空格的情况下,如何才能准确的比较两个字符串?

下面介绍几种常见的方式:

[sql]  view plain copy print ?
  1. declare @a varchar(10);set @a='maco '  
  2. declare @b varchar(10);set @b='maco'  
  3.   
  4. --第一种方式(两边都加上常量)  
  5. if(@a+'a'=@b+'a')  
  6.     select '@a与@b相等' as 方式一结果  
  7. else   
  8.     select '@a与@b不相等' as 方式一结果  
[sql]  view plain copy print ?
  1. --第二种方式(替换空格未char(13))  
  2. if(replace(@a,' ',char(13))=replace(@b,' ',char(13)))  
  3.     select '@a与@b相等' as 方式二结果  
  4. else  
  5.     select '@a与@b不相等' as 方式二结果  
[sql]  view plain copy print ?
  1. --第三种方式(都转成varbinary类型后再比较)  
  2. if(cast(@a as varbinary) = cast(@b as varbinary))  
  3.     select '@a与@b相等' as 方式三结果  
  4. else  
  5.     select '@a与@b不相等' as 方式三结果  
[sql]  view plain copy print ?
  1. --第四种方式(判断datalength)  
  2. if(@a=@b and datalength(@a)=datalength(@b))  
  3.     select '@a与@b相等' as 方式四结果  
  4. else   
  5.     select '@a与@b不相等' as 方式四结果  
[sql]  view plain copy print ?
  1. --第五种方式(用like)  
  2. if(@a=@b and @a like @b and @b like @a)  
  3.     select '@a与@b相等' as 方式五结果  
  4. else   
  5.     select '@a与@b不相等' as 方式五结果  
  6.   
  7. --运行结果  
  8. /*  
  9. 方式一结果  
  10. ------------  
  11. @a与@b不相等  
  12.   
  13. (1 row(s) affected)  
  14.   
  15. 方式二结果  
  16. ------------  
  17. @a与@b不相等  
  18.   
  19. (1 row(s) affected)  
  20.   
  21. 方式三结果  
  22. ------------  
  23. @a与@b不相等  
  24.   
  25. (1 row(s) affected)  
  26.   
  27. 方式四结果  
  28. ------------  
  29. @a与@b不相等  
  30.   
  31. (1 row(s) affected)  
  32.   
  33. 方式五结果  
  34. ------------  
  35. @a与@b不相等  
  36.   
  37. (1 row(s) affected)  
  38. */  

这里特别要说明的是用len判断是不行的。

[sql]  view plain copy print ?
  1. declare @a varchar(10);set @a='maco '  
  2. declare @b varchar(10);set @b='maco'  
  3. if(@a=@b and len(@a)=len(@b))  
  4.     select '@a与@b相等' as 方式六结果  
  5. else   
  6.     select '@a与@b不相等' as 方式六结果  
  7. /*  
  8. 方式六结果  
  9. ----------  
  10. @a与@b相等  
  11. */  

原因详见下图:



2.2 为什么会出现这个问题,是尾随空格不参与比较吗?

个人认为不是这样的。

微软的帮助中曾经提到:ANSI 标准要求填充字符的字符串比较中使用,以使其长度匹配再进行比较。进行填充时,char 列用空格填充,binary 列用零填充。

LIKE 谓词表达式的右侧功能具有尾随空格的值时, SQL Server 不会填充到相同的长度在两个值比较发生之前。(上面的方式五,只是用like做个测试)

 

3、补充说明

说到尾随空格,不得不提到SET ANSI_PADDING

在 Microsoft SQL Server 的未来版本中,ANSI_PADDING 将始终为 ON,将该选项显式设置为 OFF 的任何应用程序都将产生错误。 请避免在新的开发工作中使用该功能,并着手修改当前还在使用该功能的应用程序。

SET ANSI_PADDING:对列存储长度小于列的定义大小的值以及在 char、varchar、binary 和 varbinary 数据中含有尾随空格的值的方式进行控制。

SET ANSI_PADDING虽然在比较的时候不起作用,但是它直接控制了入口,如果设置了off,则剪裁插入 varchar 列中的字符值的尾随空格。

详见:

设置

char(n) NOT NULL 或 binary(n) NOT NULL

char(n) NULL 或 binary(n) NULL

varchar(n) 或 varbinary(n)

ON

填充原始值(char 列具有尾随空格的值,binary 列具有尾随零的值),使达到列的长度。

如果 SET ANSI_PADDING 为 ON,则遵从与 char(n) 或 binary(n) NOT NULL 相同的规则。

不剪裁插入 varchar 列中的字符值的尾随空格。 不剪裁插入 varbinary 列中的二进制值的尾随零。 不将值填充到列的长度。

OFF

填充原始值(char 列具有尾随空格的值,binary 列具有尾随零的值),使达到列的长度。

如果 SET ANSI_PADDING 为 OFF,则遵从与 varchar 或 varbinary 相同的规则。

剪裁插入 varchar 列中的字符值的尾随空格。 剪裁插入 varbinary 列中的二进制值的尾随零。

 

注:建议始终将 ANSI_PADDING 设置为 ON。

来源: 【叶子】http://blog.csdn.net/maco_wang 

这篇关于详解SQL Server 比较带有尾随空格的字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/982120

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Debezium 与 Apache Kafka 的集成方式步骤详解

《Debezium与ApacheKafka的集成方式步骤详解》本文详细介绍了如何将Debezium与ApacheKafka集成,包括集成概述、步骤、注意事项等,通过KafkaConnect,D... 目录一、集成概述二、集成步骤1. 准备 Kafka 环境2. 配置 Kafka Connect3. 安装 D

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

Spring Cloud LoadBalancer 负载均衡详解

《SpringCloudLoadBalancer负载均衡详解》本文介绍了如何在SpringCloud中使用SpringCloudLoadBalancer实现客户端负载均衡,并详细讲解了轮询策略和... 目录1. 在 idea 上运行多个服务2. 问题引入3. 负载均衡4. Spring Cloud Load

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行