Unicode字段也有collation?
来源:互联网 发布:php换行不起作用 编辑:程序博客网 时间:2024/06/05 04:36
一个常常让人困惑的问题就是,为什么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)
- Unicode字段也有collation?
- Unicode字段也有collation
- 也说Unicode
- [ZT]也说Unicode
- ('42000', '[42000] [FreeTDS][SQL Server]Unicode data in a Unicode-only collation or ntext data canno
- sql语句中某个字段有值,也有空的情况下做条件
- 有一条记录,其中有一个字段是图片路径,删除记录同时也要删除图片的执行顺序?
- JDK5.0以上:一个枚举也可以有构造函数,字段和方法,带抽象方法的枚举
- 网站也有盗版!!
- 我也有SCHEMA
- 炒冷饭也有搞头
- 我也有博客!!
- 工作也有乐趣
- 小解也有学问
- 沙子也有理想
- 说话也有温度
- 论文也有测谎仪
- 美国佬也有‘墙’
- 我当面试官的一些心得
- final
- Centos 装上VSFTPD 后 用root登录还是没有权限
- Installanywhere使用
- DNN 三种版本的比较
- Unicode字段也有collation?
- java中char,byte,short的移位操作
- 十分经典的批处理教程
- 自定义Apache日志格式
- 读过的感觉还不错的几本书
- 通过Backup Exec实施Oracle来灾难恢复
- 支点(疑惑的消除)
- Vim常用命令图示
- 使UITableView中的UITableViewCell居中显示