IT技术网www.itjs.cn

当前位置:首页 > 数据库 > SQl Server > 实践中SQL Server排序规则应用的扩展

实践中SQL Server排序规则应用的扩展

发布时间:2010-11-11 14:28 来源:未知

SQL Server排序规则相信大家都有一些的了解,接下来的SQL server内容就为您介绍SQL Server排序规则应用的一些扩展,希望可以让您对SQL Server排序规则有更深的认识。

在实践中SQL Server排序规则应用的扩展:

sql server汉字排序规则可以按拼音、笔划等排序,那么我们如何利用这种功能来处理汉字的一些难题呢?我现在举个例子:

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

要计算汉字笔划,我们得先做准备工作,我们知道,windows多国汉字,unicode目前收录汉字共20902个。简体gbk码汉字unicode值从19968开始。

首先,我们先用sqlserver方法得到所有汉字,不用字典,我们简单利用sql语句就可以得到:

select top 20902 code=identity(int,19968,1) into #t from syscolumns a,syscolumns b 

再用以下语句,我们就得到所有汉字,它是按unicode值排序的:

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

然后,我们用select语句,让它按笔划排序。

select code,nchar(code) as cnword   from #t   order by nchar(code) collate chinese_prc_stroke_cs_as_ks_ws,code 

结果:

code        cnword   ----------- ------   19968       一  20008       丨  20022       丶  20031       丿  20032       乀  20033       乁  20057       乙  20058       乚  20059       乛  20101       亅  19969       丁  .......... 

从上面的结果,我们可以清楚的看到,一笔的汉字,code是从19968到20101,从小到大排,但到了二笔汉字的第一个字“丁”,code为19969,就不按顺序而重新开始了。有了这结果,我们就可以轻松的用sql语句得到每种笔划汉字归类的第一个或最后一个汉字。