无法解决 equal to 操作的排序规则冲突

 select * from Users where username=’WangE’

什么叫排序规则呢?MS是这样描述的:”在 Microsoft SQL Server 2000 中,
字符串的物理存储由排序规则控制。排序规则指定表示每个字符的位模式以及存
储和比较字符所使用的规则。”
  在查询分析器内执行下面语句,可以得到SQL SERVER支持的所有排序规则。

完整语句是:

  select code,nchar(code) as CNWord from #t

在写sql的查询时 如下:

insert #t1(code,cnword)
select code,nchar(code) as CNWord from #t
order by nchar(code) collate Chinese_PRC_Stroke_CS_AS_KS_WS,code

 select * from Users where username=’wange’


若要使用上面的的语句能够执行按区分大小写查询 需要在查询的结尾加上
collate Chinese_PRC_CS_AI_WS

二.排序规则简介:

select * from Users where username=’WangE’ collate
Chinese_PRC_CS_AI_WS

三.排序规则的应用:
  SQL
SERVER提供了大量的WINDOWS和SQLSERVER专用的排序规则,但它的应用往往
被开发人员所忽略。其实它在实践中大有用处。

上面两条查询语句的结果是一样的,这说明username的条件并没有区分大小写。

建汉字笔划表(TAB_HZBH):
create table tab_hzbh(id int identity,cnword nchar(1))
–先插入前33个汉字
insert tab_hzbh
select top 33 A.cnword
from #t1 A
left join #t1 B on A.id=B.id-1 and

 

这样,错误就出现了:

  例2:让表NAME列的内容按姓氏笔划排序:

一.错误分析:
  这个错误是因为排序规则不一致造成的,我们做个测试,比如:
create table #t1(
name varchar(20) collate Albanian_CI_AI_WS,
value int)

  要计算汉字笔划,我们得先做准备工作,我们知道,WINDOWS多国汉字,UNICODE目前
收录汉字共20902个。简体GBK码汉字UNICODE值从19968开始。
  首先,我们先用SQLSERVER方法得到所有汉字,不用字典,我们简单利用SQL语句就
可以得到:

    select * from ::fn_helpcollations()

select *
from #t1 A inner join #t2 B
on A.name=B.name collate Chinese_PRC_CI_AI_WS

顺便引用下文章作参考:“无法解决 equal to
操作的排序规则冲突。”的错误分析和解决方法

create table #t(id int,name varchar(20))
insert #t select 1,’中’
union all select 2,’国’
union all select 3,’人’
union all select 4,’阿’

结果:
code CNWord

  上面可以看出:“亅”是所有一笔汉字排序后的最后一个字,“阝”是所有二笔汉字排序后的最后
一个字……等等。
  但同时也发现,从第33个汉字“龗(33笔)”后面的笔划有些乱,不正确。但没关系,比“龗”笔划
多的只有四个汉字,我们手工加上:齾35笔,齉36笔,靐39笔,龘64笔

create table #t1(id int identity,code int,cnword nvarchar(2))

排序规则名称由两部份构成,前半部份是指本排序规则所支持的字符集。
如:
  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区分 

4 一
2 乙
3 二
5 十
1 三
*/

4 阿
2 国
3 人
1 中
*/

SQL SERVER的排序规则平时使用不是很多,也许不少初学者还比较陌生,但有
一个错误大家应是经常碰到: SQL
SERVER数据库,在跨库多表连接查询时,若两数据
库默认字符集不同,系统就会返回这样的错误:

          用排序规则的特性计算汉字笔划

发表评论

电子邮件地址不会被公开。 必填项已用*标注