/*  
排序规则根据特定语言和区域设置的标准指定对  字符串  数据 进行排序和比较的规则。  
以 ORDER BY 子句为例:如果按升序排列,说英语的人认为字符串 Chiapas 应排在 Colima 之前。  
但是,对于在墨西哥说西班牙语的人来说,他们会认为以 Ch 开头的单词应显示在以 C 开头的单词列表的末尾。  
排序规则规定了这些排序和比较规则。Latin_1 General 排序规则在 ORDER BY ASC 子句中将 Chiapas 排在 Colima 之前,  
而 Traditional_Spanish 排序规则将 Chiapas 排在 Colima 之后。  
排序规则名称由两部份构成,前半部份是指本排序规则所支持的字符集。    
如:    
Chinese_PRC_CS_AI_WS     
前半部份:指UNICODE字符集,Chinese_PRC_指针对大陆简体字UNICODE的排序规则。    
排序规则的后半部份即后缀 含义:     
_BIN 二进制排序     
_CI(CS) 是否区分大小写,CI不区分,CS区分    
_AI(AS) 是否区分重音,AI不区分,AS区分     
_KI(KS) 是否区分假名类型,KI不区分,KS区分     
    _WI(WS) 是否区分宽度 WI不区分,WS区分     
区分大小写:如果想让比较将大写字母和小写字母视为不等,请选择该选项。    
区分重音:如果想让比较将重音和非重音字母视为不等,请选择该选项。如果选择该选项,比较还将重音不同的字母视为不等。    
区分假名:如果想让比较将片假名和平假名日语音节视为不等,请选择该选项。    
区分宽度:如果想让比较将半角字符和全角字符视为不等,请选择该选项。    
修改排序规则    
如果是数据库:ALTER DATABASE 数据库名 COLLATE 排列规则    
ALTER DATABASE test COLLATE Chinese_PRC_CI_AI   
如果是表中的字段:ALTER TABLE 表名 ALTER COLUMN 字段名 数据类型(长度) COLLATE 排列规则    
ALTER TABLE test ALTER COLUMN name varchar(10) COLLATE Chinese_PRC_CI_AI   
*/
--所有排序规则     
SELECT  * FROM    :: FN_HELPCOLLATIONS()      
-----------------------------------------------------------------------------------     
--1.为数据库指定排序规则     
CREATE DATABASE test1 COLLATE Chinese_PRC_CI_AS      
GO     
CREATE DATABASE test2 COLLATE Chinese_Hong_Kong_Stroke_90_CI_AI     
GO     
USE test1    
go     
CREATE TABLE a 
    ( 
      col1 VARCHAR(10) , 
      col2 VARCHAR(10) 
    )     
INSERT INTO a 
SELECT  'a1' , 'a2' 
UNION ALL 
SELECT  'a3' , 'a4'    
GO     
--------------- 
USE test2    
go     
CREATE TABLE a 
    ( 
      col1 VARCHAR(10) , 
      col2 VARCHAR(10) 
    )     
GO     
INSERT INTO a 
SELECT  'a1' , 'a2' 
UNION ALL 
SELECT  'a5' , 'a6'    
----------------- 
SELECT  * FROM    test1.dbo.a     
SELECT  * FROM    test2.dbo.a     
--转换规则,语句执行无错   
SELECT  *  FROM    test1.dbo.a aa , test2.dbo.a bb 
WHERE   aa.col1 = bb.col1 COLLATE Chinese_PRC_CI_AS     
SELECT  * FROM    test1.dbo.a aa , test2.dbo.a bb 
WHERE   aa.col1 = bb.col1   --这句单独执行,出错 ,无法解决 equal to 操作中 "Chinese_Hong_Kong_Stroke_90_CI_AI" 和 "Chinese_PRC_CI_AS" 之间的排序规则冲突。     
--排序规则不一样,无法比较字符串 ,字段,需要转换规则.使其一致,好比2个人做比较,谁厉害点,指定一个规则,如这2个人sql方面做比较 
USE master     
go     
DROP DATABASE test1    
go     
DROP DATABASE test2    
-----------------------------------------------------------------------------------    
--2.为表中的列指定排序规则     
CREATE TABLE #t1 
    ( 
      col1 VARCHAR(10) , 
      col2 VARCHAR(10) COLLATE Chinese_PRC_CI_AS 
    )     
GO     
INSERT INTO #t1 
SELECT  'a1' ,'a2' 
UNION ALL 
SELECT  'a3' ,'a4'    
CREATE TABLE #t2 
    ( 
      col1 VARCHAR(10) , 
      col2 VARCHAR(10) COLLATE Chinese_Hong_Kong_Stroke_90_CI_AI 
    )     
GO     
INSERT INTO #t2 
SELECT  'a1' ,'a2' 
UNION ALL 
SELECT  'a3' ,'a4'    
SELECT  * FROM    #t1    
SELECT  * FROM    #t2    
--没错误     
SELECT  * FROM    #t1 aa JOIN #t2 bb ON aa.col1 = bb.col1    
--转换规则     
SELECT  * FROM    #t1 aa , #t2 bb  WHERE   aa.col2 = bb.col2 COLLATE Chinese_PRC_CI_AS     
SELECT  * 
FROM    #t1  JOIN #t2 ON #t1.col2 = #t2.col2  --出错,无法解决 equal to 操作中 "Chinese_Hong_Kong_Stroke_90_CI_AI" 和 "Chinese_PRC_CI_AS" 之间的排序规则冲突。     
DROP TABLE #t1    
DROP TABLE #t2    
-----------------------------------------------------------------------------------     
--3.为字符变量指定排序规则     
DECLARE @a VARCHAR(10) , 
    @b VARCHAR(10)   
SELECT  @a = 'a' , 
        @b = 'A'   
--使用排序规则 Chinese_PRC_CI_AS   
SELECT  CASE WHEN @a COLLATE Chinese_PRC_CI_AS = @b THEN '@a=@b' 
ELSE '@a<>@b' 
END
--结果:@a=@b   
--使用排序规则 Chinese_PRC_BIN   
SELECT  CASE WHEN @a COLLATE Chinese_PRC_BIN = @b THEN '@a=@b' 
ELSE '@a<>@b' 
END
--结果:@a<>@b   
SELECT  @a  
SELECT  @b  
--按笔画姓氏查询  
SELECT  * FROM    TableName  ORDER BY CustomerName COLLATE Chinese_PRC_Stroke_ci_as       
-----------------------------------------------------------------------------------    

 

原文地址:http://www.cnblogs.com/qanholas/archive/2010/09/16/1828163.html

sql server 排序规则的更多相关文章

  1. 利用脚本修改SQL SERVER排序规则

    利用脚本修改SQL SERVER排序规则 编写人:CC阿爸 2014-3-1 l  今年的一项重要工作是对公司所用系统进行繁简的转换,程序转成简体基本很容易解决,但数据库转换成简体,就没那么容易了.经 ...

  2. SQL Server 排序规则的影响

    目录 SQL Server 排序规则 影响 效果演示 更改数据库排序规则 服务器级排序规则 数据库级排序规则 列级排序规则 查询时指定规则 建议 使用 Unicode 数据类型 使用二进制排序规则 [ ...

  3. sql server ------创建本地数据库 SQL Server 排序规则

    sql server完整复制数据库 sql server导入导出方法 SQL Server 排序规则

  4. SQL Server排序规则

    在使用数据库的过程中,总会碰到一些特别的需求.有时候需要储存中文字符,区分大小写或者按照中文的比划顺序排序.这就涉及到了对数据库排列规则的选择. 我们一般可以选择数据库名称-->右键属性(Pro ...

  5. 根据SQL Server排序规则创建顺序GUID

    public static class GuidUtil { , , , , , , DateTimeKind.Utc).Ticks / 10000L; /// <summary> /// ...

  6. SQL Server排序规则不一致 - Collate Database_Default

    http://www.cnblogs.com/chencidi/archive/2014/07/02/3820386.html 使用多库查询时会出现排序规则冲突的问题 解决办法 在字段后面添加Coll ...

  7. Sql Server 排序规则字符集的冲突问题

    可通过如下sql 进行修改: 如果整个DB都不一致: Alter database Expense_Portal collate Chinese_PRC_CI_AS 某张Table的栏位不一致: ) ...

  8. 修改SQL Server 排序规则 (未能排它地锁定数据库以执行该操作)

    use master go alter database DBName set single_user go alter database DBName COLLATE Chinese_PRC_CI_ ...

  9. SQL Server排序函数row_number和rank的区别

    SQL Server排序函数row_number和rank的区别 直接看测试结果 declare @table table(name varchar(100),amount int, memo var ...

随机推荐

  1. windows-ubuntu环境变量的设置格式的不同

    1  在Ubuntu下输出环境变量,比如JAVA_HOME, 使用cat或者echo $JAVA_HOME即可,但是在windows下不可以, windows不支持cat命令,只能使用echo %JA ...

  2. Android库Volley的使用介绍

    Android Volley 是Google开发的一个网络lib,可以让你更加简单并且快速的访问网络数据.Volley库的网络请求都是异步的,你不必担心异步处理问题. Volley的优点: 请求队列和 ...

  3. 多个storyboard开发应用程序,封装.bundle和.a不用xib使用storyboard!!!

    一,封装.bundle和.a使用xib的方式前面已经说过了,具体方式不再赘述,简单介绍于下: 静态库加.h  bundle:删plist,改sdk,加xib 简称psx三步 引用库的项目,加.a .b ...

  4. (Your)((Term)((Project)))

    Description You have typed the report of your term project in your personal computer. There are seve ...

  5. BUAA 724 晴天小猪的神题(RMQ线段树)

    BUAA 724 晴天小猪的神题 题意:中文题,略 题目链接:http://acm.buaa.edu.cn/problem/724/ 思路:对于询问x,y是否在同一区间,可以转换成有没有存在一个区间它 ...

  6. utf8与utf-8的区别

    相信很多程序员刚开始也会有这样的疑惑,如题,我也是.    其实,他们可以这样来区分.    一.在php和html中设置编码,请尽量统一写成“UTF-8”,这才是标准写法,而utf-8只是在wind ...

  7. 第三个sprint第一天

    一.例会人员:李泳江,邵家文,周伟雄,谢洪跃 日期:6月16号   例会内容: 1.更新核心功能 例会地点:宿舍 二.任务展示 编号 名称 时间 已用时间 是否完成 1 画出算法流程图 4小时 4小时 ...

  8. dedecms SQL数据库连接信息注解(借鉴)

    <?php $cfg_dbhost = 'localhost'; //数据库地址,这里的localhost指的是本机$cfg_dbname = 'hunuo'; //数据库名$cfg_dbuse ...

  9. Java Super 覆盖方法

    子类从父类中继承方法,有时候,子类需要修改父类中定义的方法的实现,这称作方法覆盖. 比如,GeometricObject类中的toString方法返回表示集合对象的字符串,这个方法就可以被覆盖,返回表 ...

  10. UVa 10120 - Gift?!

    题目大意 美丽的村庄里有一条河,N个石头被放置在一条直线上,从左岸到右岸编号依次为1,2,...N.两个相邻的石头之间恰好是一米,左岸到第一个石头的距离也是一米,第N个石头到右岸同样是一米.礼物被放置 ...