一个关于空格的Sql Server面试题

引子

先上题目:

回答下面sql 的输出结果

declare @s1 varchar(10)

declare @s2 varchar(10)

set @s1='a b'

set @s2='a b'

if @s1=@s2 select 'true'

答案是 true

那么上面的 s1 和 s2 是否相等的呢?

我们再看看下面的sql

sql 复制代码
declare @s1 varchar(10)
declare @s2 varchar(10)
set @s1='A b'
set @s2='A b'  
if @s1=@s2 select 'true' 

答案也是 true

这道面试题的目的是以题目为契机,引出数据库下面的知识点:

1、字符串字段

2、排序规则

3、排序规则和相等的关系

分析

我们开始分析s1 和 s2 这俩字符串。他们是否相等,如果我们用c++、delphi、C# 等语言来判断,显示是不等,但是在sql server中,有时候是相等的(如上图)。

sql server 和 c++、delphi、C# 的运算 结果不一样,他们之中谁错了?

他们都没有错,因为他们都是按照自己的规则运算的。c++、delphi、C#等语言是字符串处理,俺就不谈了,C++的字符串操作可以写半本书。

我们先从 sql server的字符串类型开始说,sql server的字符串类型常用的有:

  • char(32)
  • varchar(31)
  • nchar(31)
  • nvarchar(31)
  • text
  • varchar(max)
  • nvarchar(max)

除了类型之外,还要一个需要的注意的就是排序规则。

执行SELECT DATABASEPROPERTYEX('master', 'Collation')

在Chinese_PRC_CI_AS下,上面的s1 和 s2 的每个字符的排序是一致的,所以 sql server 认为 s1 和 s2 是相等的。由此可以看出,在 sql server 中的字符串比较是按照Chinese_PRC_CI_AS进行计算的。

另:Chinese_PRC_CI_AS

Chinese_PRC_CI_AS,前半部份:指UNICODE字符集,Chinese_PRC_指针对大陆简体字UNICODE的排序规则。

排序规则的后半部份即后缀 含义:

_BIN: binary sort 二进制排序

_BIN2:binary code point comparison sort

_AS、_WS等选项的字母代表的意义如下:

C:case,大小写

A:accent,重音

K:kanatype,假名

W:width,宽度

I:insensitive, 不敏感,不区分

S:sensitive,敏感,区分

如 CI 就是case-insensitive,不区分大小写。

更详细说明:

_CI(CS) :是否区分大小写,CI不区分,CS区分。

_AI(AS) :是否区分重音,AI不区分,AS区分。

_KI(KS) :是否区分假名类型,KI不区分,KS区分。

_WI(WS) :是否区分宽度 WI不区分,WS区分。

提示说明:

区分大小写:如果想让比较将大写字母和小写字母视为不等,请选择该选项。

区分重音:如果想让比较将重音和非重音字母视为不等,请选择该选项。如果选择该选项。比较还将重音不同的字母视为不等。

区分假名:如果想让比较将片假名和平假名日语音节视为不等,请选择该选项。
区分宽度:如果想让比较将半角字符和全角字符视为不等,请选择该选项。

相关推荐
m0_564264186 小时前
IDEA DEBUG调试时如何获取 MyBatis-Plus 动态拼接的 SQL?
java·数据库·spring boot·sql·mybatis·debug·mybatis-plus
隐语SecretFlow7 小时前
隐语SecreFlow SCQL 1.0.0b1 发布:更完善的 SQL 支持与更高效的隐私查询引擎
数据库·sql
悟能不能悟13 小时前
在service方法中已经catch异常,Transactional失效怎么办
java·数据库·sql
未孤_有青山13 小时前
库卡机器人通讯-EtherKRL-XML格式
xml·c#
zimoyin13 小时前
解决导入的数据库中因为 sql_mode 不同 视图无法打开问题
数据库·sql
課代表14 小时前
VB.NET 与 C# 文件操作文本到二进制文件的读写
c#·二进制文件·vb.net·streamwriter·文本文件·读写·streamreader
码界奇点14 小时前
Java 开发日记MySQL 与 Redis 双写一致性策略挑战与实战解析
java·redis·sql·mysql·java-ee
我是唐青枫14 小时前
C#.NET Cronos 实战:优雅解析与执行 Cron 表达式
c#·.net
还是大剑师兰特14 小时前
C#面试题及详细答案120道(41-50)-- 异常处理
c#·大剑师
Hare_bai15 小时前
WPF的MVVM模式核心架构与实现细节
ui·架构·c#·wpf·交互·xaml·mvvm