博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Unicode字段也有collation
阅读量:6720 次
发布时间:2019-06-25

本文共 1318 字,大约阅读时间需要 4 分钟。

原文:

转自:

一个常常让人困惑的问题就是,为什么SQL Server 的Unicode 字段(nvarchar/nchar/ntext)也有collation定义呢?Unicode字段不是可以存储多语言吗?比如下面的表定义:

 

CREATE TABLE tt1

(

  c1 int,

  c2 nvarchar(10)  collate Chinese_PRC_Stroke_CI_AS

 )

 

上门的c2 字段是nvarchar类型,那么加的collate Chinese_PRC_Stroke_CI_AS有啥意义呢。 或许你会问,如果我不加上collate不就行啦. 其实如果没有后面的collate, SQL server 会缺省给你加上数据库的collation. 也就是说nvarchar/nchar等字段一定是有collation的.

 

那么上面定义的collate有何意义?是否就是指这个c2字段只能存放中文字符呢?不是. Unicode 的collation 的作用是排序规则. 就是说, 这个字段依旧可以存放多国语言,但是你只能指定一种排序规则,如上面的table, 我指定的排序规则就是按照中文排序,即使你存放的是别的语言..

 

让我们看一看例子:

 

IF OBJECT_ID ('tt1','U') IS NOT NULL

drop table tt1

go

CREATE TABLE tt1

(

  c1 int,

  c2 nvarchar(10)  collate Chinese_PRC_Stroke_CI_AS

 )

  

go  

 

INSERT tt1 VALUES (1, N'');

INSERT tt1 VALUES (2, N'');

INSERT tt1 VALUES (3, N'');

INSERT tt1 VALUES (4, N'');

GO

select * from tt1 order by c2

 

结果如下:

 

c1          c2

----------- ----------

1           一

2           二

3           三

4           四

 

(4 row(s) affected)

 

你可以看到c2列的排序结果不错. 如果我们使用另外一种collation, 那么结果可能是不同的,让我们看看:

 

IF OBJECT_ID ('tt1','U') IS NOT NULL

drop table tt1

go

CREATE TABLE tt1

(

  c1 int,

  c2 nvarchar(10)  collate latin1_general_cs_as

 )

  

go  

 

INSERT tt1 VALUES (1, N'');

INSERT tt1 VALUES (2, N'');

INSERT tt1 VALUES (3, N'');

INSERT tt1 VALUES (4, N'');

GO

select * from tt1 order by c2

 

 

结果是不一样的, C2列的order by 结果和上面是有差异的:

 

c1          c2

----------- ----------

1           一

3           三

2           二

4           四

 

(4 row(s) affected)

转载地址:http://lrjmo.baihongyu.com/

你可能感兴趣的文章
UDP/TCP通信小记
查看>>
对Inode、Hard Link以及Soft Link的理解
查看>>
SubareaOpr
查看>>
1111. Online Map (30)
查看>>
PhpStorm 运行出现502 Bad Gateway
查看>>
Python - 100天从新手到大师
查看>>
关于window.open()的新认识
查看>>
WinForm排列MDI子窗体
查看>>
软件工程作业-高频词查找
查看>>
【网新】3月28【NSString练习】
查看>>
Celery底层原理
查看>>
sos 怎么在代码里设置将一个imagebutton放在屏幕的中间
查看>>
常用的列表和元祖
查看>>
红米4A手机刷开发版rom并且获取root权限
查看>>
if语句三种形式
查看>>
C# PDF 全攻略
查看>>
用户场景分析
查看>>
Linux下QT和qtCreator安装配置
查看>>
javascript+dom 编程艺术<2>
查看>>
你人生最重的枷锁是什么?
查看>>