SQL Server的排序规则(collation)冲突和解决方案

WBOY
发布: 2016-06-07 16:21:15
原创
2046 人浏览过

什么是排序规则(collation) 关于SQL Server的排序规则,估计大家都不陌生,在创建数据库时我们经常要选择一种排序规则(conllation),一般我们会留意到每一种语言的排序规则都有许多种,比如标准大陆简体中文Chinese_PRC的排序规则就有数十种之多。 这些排序

   什么是排序规则(collation)

  关于SQL Server的排序规则,估计大家都不陌生,在创建数据库时我们经常要选择一种排序规则(conllation),一般我们会留意到每一种语言的排序规则都有许多种,比如标准大陆简体中文Chinese_PRC的排序规则就有数十种之多。

SQL Server的排序规则(collation)冲突和解决方案  三联

  这些排序规则有什么作用呢?让我们先来看看MS官方的解释:

  排序规则指定了表示每个字符的位模式。它还指定了用于排序和比较字符的规则。排序规则具有下面的特征:

  语言

  区分大小写

  区分重音

  区分假名

  比如在SQL Server 2005中,排序规则名称由两部份构成,比如 Chinese_PRC_CI_AI_WS

  前半部份是指本排序规则所支持的字符集,,如Chinese_PRC 指针对大陆简体字UNICODE的排序规则。

  后半部份即后缀的含义如下:

_BIN                 指定使用向后兼容的二进制排序顺序。

_BIN2      指定使用 SQL Server 2005 中引入的码位比较语义的二进制排序顺序。

_Stroke   按笔划排序

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

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

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

_WI(WS) 是否区分全半角,WI不区分,WS区分

  既然排序规则如此复杂,那么应用了不同排序规则的列之间默认情况下便不能进行Union、Join、Like等equal操作了,于是便有了排序规则(collation)冲突。

  排序规则(collation)冲突。

  我们知道,SQL Server 从2000 开始,便支持多个排序规则。SQL Server 2000 的数据库可使用除默认排序规则以外的其他排序规则。此外,SQL Server 2000 还支持为列专门制定排序规则。

  这样一来,我们在写跨表、跨数据库、跨服务器操作的T-SQL时,如果equal的字段排序规则不同,便会发生排序规则冲突。

  比如我们先见两个结构相同的表,但字段的排序规则不同:

  Copy to Clipboard

  -- 1. Create TableA.

  CREATE TABLE TagsTableA

  (

  TagName NVARCHAR(64) COLLATE Chinese_PRC_BIN

  )

  -- 2. Create TableB.

  CREATE TABLE TagsTableB

  (

  TagName NVARCHAR(64) COLLATE Chinese_PRC_CI_AS

  )

  当表建好之后执行:

  Copy to Clipboard

  -- 3. Try to join them

  SELECT * from TagsTableA A INNER JOIN TagsTableB B on A.TagName = B.TagName

  便会出下类似下面的问题:

  无法解决 equal to 操作中 "Chinese_PRC_BIN" 和 "Chinese_PRC_CI_AS" 之间的排序规则冲突。

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!