ITPub博客

首页 > Linux操作系统 > Linux操作系统 > ORACLE中文排序

ORACLE中文排序

原创 Linux操作系统 作者:liuya1985liuya 时间:2007-12-27 14:31:43 0 删除 编辑

Oracle9i之前,中文是按照二进制编码进行排序的。
在oracle9i中新增了按照拼音、部首、笔画排序功能。设置NLS_SORT值
SCHINESE_RADICAL_M 按照部首(第一顺序)、笔划(第二顺序)排序
SCHINESE_STROKE_M 按照笔划(第一顺序)、部首(第二顺序)排序
SCHINESE_PINYIN_M 按照拼音排序
修改ORACLE字段的默认排序方式:
按拼音(默认):  alter session set nls_sort = SCHINESE_PINYIN_M;
按笔画:alter session set nls_sort = SCHINESE_STROKE_M;
按偏旁:alter session set nls_sort = NLS_SORT=SCHINESE_RADICAL_M;


select * from cc order by nlssort(b,'NLS_SORT=SCHINESE_PINYIN_M');
说明:按拼音字母(英文字母)排序是ORACLE默认的排序方式,除非已经修改过

select * from cc order by nlssort(b,'NLS_SORT=SCHINESE_STROKE_M');

select * from cc order by nlssort(b,'NLS_SORT=SCHINESE_RADICAL_M');

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/8750110/viewspace-6698/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2007-12-13

  • 博文量
    26
  • 访问量
    90682