转自:https://www.cnblogs.com/a393060727/p/3224363.html
Oracle在9i之前是对汉字的排序是按照二进制编码进行排序的,很不适合我们的国情,在Oracle 9i之后,汉字的排序方式有了以下三种方式:
这样,就可以在查询的时候,指定汉字的排序方式,设定方式可以分为以下三个级别:
按照笔划排序:
select * from table order by nlssort(col,'NLS_SORT=SCHINESE_STROKE_M');
按照部首排序:
select * fromtableorder by nlssort(col,'NLS_SORT=SCHINESE_RADICAL_M');
按照拼音排序:
select * from table order by nlssort(col,'NLS_SORT=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;
set NLS_SORT=SCHINESE_RADICAL_M; export NLS_SORT (sh)setenv NLS_SORT SCHINESE_RADICAL_M (csh) HKLC\SOFTWARE\ORACLE\home0\NLS_SORT (Windows注册表);