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

数据库 SQL Server
SQL Server中字符串的物理存储由排序规则控制,下文对SQL Server排序规则应用的扩展作了详尽的阐述,如果您感兴趣的话,不妨一看。

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

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

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

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

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

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

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

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

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

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

  1. select code,nchar(code) as cnword   
  2. from #t   
  3. order by nchar(code) collate chinese_prc_stroke_cs_as_ks_ws,code 

结果:

  1. code        cnword   
  2. ----------- ------   
  3. 19968       一  
  4. 20008       丨  
  5. 20022       丶  
  6. 20031       丿  
  7. 20032       乀  
  8. 20033       乁  
  9. 20057       乙  
  10. 20058       乚  
  11. 20059       乛  
  12. 20101       亅  
  13. 19969       丁  
  14. .......... 

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

 

 

【编辑推荐】

带您了解SQL Server标识列

SQL Server UPDATE语句的用法

SQL Server中select into语法详解

SQL Server创建表和删除表

SQL SERVER TOC分页的实现方法

责任编辑:段燃 来源: 互联网
相关推荐

2010-11-11 14:14:52

SQL Server排

2010-11-11 14:05:17

SQL Server排

2010-07-21 10:41:55

SQL Server

2010-07-05 17:55:26

SQL Server更

2010-07-21 10:21:49

SQL Server

2010-07-21 10:27:49

SQL Server

2010-07-01 11:20:38

SQL Server

2010-07-06 08:36:55

SQL Server实

2010-07-21 10:36:18

SQL Server

2010-07-21 10:15:43

SQL Server

2022-12-09 11:46:20

2010-07-01 11:03:04

SQL Server转

2010-11-12 13:08:36

动态sql语句

2010-07-21 10:05:29

SQL Server排

2011-08-25 15:19:25

SQL Server 排序规则

2010-07-05 18:02:37

SQL Server数

2021-06-03 08:32:52

KubernetesRBACRole

2023-01-14 22:59:34

2016-11-09 15:49:28

大数据金融WOT2016

2009-04-16 17:53:09

SQL Server 应用程序扩展性
点赞
收藏

51CTO技术栈公众号