oralce针对汉字的排序

来源:这里教程网 时间:2026-03-03 19:33:23 作者:

在Oracle 9i之前,汉字排序是基于二进制编码。从Oracle 9i起,引入了更加灵活的汉字排序方式,主要有三种:

  1. 拼音排序 ( NLS_SORT=SCHINESE_PINYIN_M )

  2. 笔画排序 ( NLS_SORT=SCHINESE_STROKE_M )

  3. 偏旁部首排序 ( NLS_SORT=SCHINESE_RADICAL_M )

这些排序方式可以在不同的级别上设置,包括语句级别、会话级别和系统级别,以满足不同的应用需求。

1. 语句级别设置排序方式

  • 按笔画排序

    
    
    
    SELECT * FROM table ORDER BY nlssort(col, 'NLS_SORT=SCHINESE_STROKE_M');
  • 按部首排序

    
    
    
    SELECT * FROM table ORDER BY nlssort(col, 'NLS_SORT=SCHINESE_RADICAL_M');
  • 按拼音排序

    
    
    
    SELECT * FROM table ORDER BY nlssort(col, 'NLS_SORT=SCHINESE_PINYIN_M');

    2. Session级别设置

  • 按拼音

    
    
    
    ALTER SESSION SET nls_sort = SCHINESE_PINYIN_M;
  • 按笔画

    
    
    
    ALTER SESSION SET nls_sort = SCHINESE_STROKE_M;
  • 按偏旁

    
    
    
    ALTER SESSION SET nls_sort = SCHINESE_RADICAL_M;

    3. 系统参数设置

  • Linux/Unix

    
    
    
    export NLS_SORT=SCHINESE_RADICAL_M
  • Windows

    
    
    
    在注册表中设置:HKLC\SOFTWARE\ORACLE\home0\NLS_SORT=SCHINESE_RADICAL_M

    检查设置

    为了验证排序设置是否生效,可以使用以下查询来查看Oracle的一些默认参数:

    
    
    
    SELECT * FROM nls_database_parameters WHERE parameter LIKE '%NLS_SORT%';

    案例:

    建表: CREATE TABLE students (  id INT PRIMARY KEY,  name VARCHAR2(50),  score INT); 插入数据:INSERT INTO students (id, name, score) VALUES (1, '张三', 88);INSERT INTO students (id, name, score) VALUES (2, '李四', 95);INSERT INTO students (id, name, score) VALUES (3, '王五', 76);INSERT INTO students (id, name, score) VALUES (4, '赵六', 82);INSERT INTO students (id, name, score) VALUES (5, '陈七', 91);

    演示不同的排序方式

    按拼音排序:

    按笔画排序:

    按偏旁部首排序:

  • 相关推荐