oracle的order by 中文排序原理
Posted 丿似锦
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle的order by 中文排序原理相关的知识,希望对你有一定的参考价值。
近期发现oracle的order by中文排序并不是完全按照拼音排序的
经过测试发现oracle的order by中文排序是按照中文的ASCII码排序的
查询字符ASCII码 select ascii(‘燀‘) from dual;
这里说一下oracle中的汉字分类:
一级汉字,是最常用的汉字,按汉语拼音字母顺序排列,共3755个;
二级汉字,属于次常用汉字,按偏旁部首的笔划顺序排列,共3008个
所以可能存在一些二级汉字的首字母是一级汉字的首字母之前的,会排序在一级汉字之后
正确排序方式:
1.按照拼音顺序 ORDER BY nlssort(NAME, ‘NLS_SORT=SCHINESE_PINYIN_M‘);
2.按照部首顺序
ORDER BY nlssort(NAME, ‘NLS_SORT=SCHINESE_RADICAL_M‘);
3.按照笔画顺序
ORDER BY nlssort(NAME, ‘NLS_SORT=SCHINESE_STROKE_M‘);
结束
以上是关于oracle的order by 中文排序原理的主要内容,如果未能解决你的问题,请参考以下文章