转载自:http://blog.163.com/light_warm/blog/static/3168104200910238554457/

 

之前碰到了数据库排序规则冲突问题,即百度或者Google的老话题:无法解决equal to操作中‘sql_latin1_general_cp1_ci_as’和‘chinese_prc_ci_as’之间的排序规则冲突。一般的方法,是在创建临时表或表连接的时候加上规则校勘语句COLLATE “规则名”解决,如:

 

create table #example (

    EXP_Name varchar(50) collate CHINESE_PRC_CI_AS NULL

)

 

select *

from A inner join B

on A.name=B.name collate Chinese_PRC_CI_AI_AS

select *

from A inner join B

on A.name collate Chinese_PRC_CI_AI_AS =B.name

 

但是,当一个数据库有很多触发器、存储过程或者函数需要修改的时候,这种方法显得不够显示,即使是将当中的内容导出成.sql文件再用替换的方法修改,也是比较麻烦的。曾经试图更改相关数据表的列,甚至数据库的排序规则,如:

ALTER DATABASE 数据库名 COLLATE 排列规则,例如:

ALTER DATABASE dbexp COLLATE Chinese_PRC_CI_AI

ALTER DATABASE AutoUpgrade COLLATE Chinese_PRC_CI_AI

alter database database_name collate collate_name

这里为Chinese_PRC_CI_AI_AS

对于数据库字段,则有:

ALTER TABLE 表名 ALTER COLUMN 字段名 数据类型(长度) COLLATE 排列规则

例如:

ALTER TABLE Userinfo ALTER COLUMN name varchar(4) COLLATE Chinese_PRC_CI_AI

或者通过数据库的“属性->选项”更改排序规则,但是,当整个数据库服务器的排序规则与我们所需的规则不一致时,这种方法也不能解决问题,这时候可以重装或修复数据库服务器。显然,修复要比重装的工作量小。用CMD窗口进入安装目录,如插入光盘或者安装文件在某个目录下,输入如下语句运行:

start /wait setup.exe /qb INSTANCENAME=MSSQLSERVER REINSTALL=SQL_Engine REBUILDDATABASE=1 SAPWD=test SQLCOLLATION= Chinese_PRC_CI_AS

其中,加粗部分是规则名,可以使别的规则。

现在附上关于一些排序规则描述

(来自http://www.itwis.com/html/database/sqlserver/20080613/1732.html):

排序规则名称由两部份构成,前半部份是指本排序规则所支持的字符集。

如:

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区分

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

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

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

区分宽度:如果想让比较将半角字符和全角字符视为不等,请选择该选项。