实践中SQL Server排序规则应用的扩展
2023-04-18 15:55:25 时间
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语句得到每种笔划汉字归类的***个或***一个汉字。
【编辑推荐】
相关文章
- 直接在代码里面对list集合进行分页
- .NET Framework 4.5新特性详解
- 大数据的简要介绍
- 大数据的由来
- 高斯混合模型的自然梯度变量推理
- timing-wheel 仿Kafka实现的时间轮算法
- 使用Navicat软件连接自建数据库(Linux系统)
- 那一天,我被Redis主从架构支配的恐惧
- Redis 深入了解键的过期时间
- C#使用委托调用实现用户端等待闪屏
- 基于流计算 Oceanus 和 Elasticsearch Service 构建百亿级实时监控系统
- GRAND | 转录调控网络预测数据库
- JFreeChart API中文文档
- 临床相关突变查询数据库
- TIGER | 人类胰岛基因变化查询数据库
- 视频边缘计算网关EasyNVR在视频整体监控解决方案中的应用分析
- Apache Arrow - 大数据在数据湖后的下一个风向标
- 常见的电商数据指标体系
- AKShare-艺人数据-艺人流量价值
- MySQL中多表联合查询与子查询的这些区别,你可能不知道!