`

oracle 排序(中文,null的处理)

阅读更多
oracle在9i之前是对汉字的排序是按照二进制编码进行排序的,很不适合我们的国情,在oracle9i之后,汉字的排序方式有了以下三种方式:
    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级别的设置,修改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;
        3、修改系统参数(数据库所在操作系统):
       set NLS_SORT=SCHINESE_RADICAL_M ;export NLS_SORT (sh)setenv NLS_SORT SCHINESE_RADICAL_M (csh)  HKLCSOFTWAREORACLEhome0NLS_SORT (win注册表);

        网上有人说,oracle9i之后对于汉字的默认排序是拼音排序(SCHINESE_PINYIN_M),但是经过我的实际验证,发现不是,排序比较乱,也不知道是不是按照二进制编码进行排序的。

        使用如下方法可以查看oracle的一些默认参数(注意标红的参数值):
Connected to Oracle Database 10g Enterprise Edition Release 10.2.0.1.0
Connected as system
SQL>
SQL> select * from nls_database_parameters;

PARAMETER                      VALUE
------------------------------ ----------------------------------------------------

NLS_LANGUAGE                   AMERICAN
NLS_NCHAR_CHARACTERSET         UTF8
NLS_TERRITORY                  AMERICA
NLS_CURRENCY                   $
NLS_ISO_CURRENCY               AMERICA
NLS_SORT                       BINARY
NLS_NUMERIC_CHARACTERS         .,
NLS_CHARACTERSET               AL32UTF8
NLS_CALENDAR                   GREGORIAN
NLS_DATE_FORMAT                DD-MON-RR
NLS_DATE_LANGUAGE              AMERICAN
NLS_TIME_FORMAT                HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT           DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT             HH.MI.SSXFF AM TZR
NLS_TIMESTAMP_TZ_FORMAT        DD-MON-RR HH.MI.SSXFF AM TZR
NLS_DUAL_CURRENCY              $
NLS_COMP                       BINARY
NLS_LENGTH_SEMANTICS           BYTE
NLS_NCHAR_CONV_EXCP            FALSE
NLS_RDBMS_VERSION              10.2.0.1.0

分享到:
评论

相关推荐

    oracle排序

    在 Oracle 中,可以使用 DECODE 函数对 NULL 值进行处理。例如,以下语句将对 perexl 表中的数据按照 danwei 列进行排序,并将 NULL 值转换为“单位是空”: SELECT * FROM perexl ORDER BY DECODE(danwei, NULL, '...

    oracle处理的类型 oracle行排序

    本文将主要探讨Oracle如何处理不同类型的数据库操作,特别是涉及到行排序的知识点。在Oracle中,对数据进行排序是日常查询和分析工作中非常常见的一种需求。 首先,我们需要理解在Oracle中进行数据排序的基本语法,...

    对Oracle 排序中的几种常用排序的介绍

    1. **按拼音排序**:Oracle支持按照汉字的拼音进行排序,这在处理中文数据时非常有用。可以使用`NLSSORT`函数配合`NLS_SORT`参数来实现。例如,以下语句会按照汉语拼音对`danwei`字段进行升序排序: ```sql select...

    Oracle数据库中对null值的排序及mull与空字符串的区别

    order by排序之null值处理方法 在对业务数据排序时候...这是四种oracle排序中NULL值处理的方法: 1、使用nvl函数 语法:Nvl(expr1, expr2)  若EXPR1是NULL,則返回EXPR2,否則返回EXPR1. SELECT NAME,NVL(TO_CHAR(CO

    oracle使用order by排序null值如何处理

    适用情况: oracle 对查询结果进行排序时,被排序的栏位存在null值,且要指定NULL值排在最前面或者最后面 关键字:Nulls First;Nulls Last 默认情况:null 默认为最大值(即:asc 升序<小–>大>,null值排在最后...

    oracle汉字转拼音函数整理大全

    在Oracle数据库中,有时需要将汉字转换成拼音,尤其是在处理中文数据时。本篇文档详细介绍了两种用于转换汉字到拼音的自定义函数:`fn_getpyKGJG` 和 `fn_getpyWKG`。这些函数能够满足不同场景下对拼音格式的需求,...

    关于Oracle中NULL使用的若干实验研究.pdf

    在排序时,Oracle默认会将NULL值排在最后,除非特别指定排序规则。 总的来说,理解Oracle中NULL的使用至关重要,因为它会影响到查询性能、数据完整性和程序的正确性。开发者需要谨慎处理涉及NULL的操作,避免出现因...

    Oracle 中文字段进行排序的sql语句

    在Oracle数据库中,对中文字段进行排序是一项常见的需求,特别是在处理中文字符的数据时。Oracle提供了多种方式来实现中文字段的排序,包括按照笔画、部首以及拼音。下面将详细阐述这些方法及其背后的原理。 首先,...

    MLDN魔乐科技JAVA培训_Oracle课堂6_排序、单行函数.rar

    这堂课程可能详细讲解了如何在Java程序中与Oracle数据库交互,如何编写SQL语句进行排序操作,以及如何利用Oracle的单行函数进行数据处理。通过观看提供的视频,学习者将能够深化对Java编程和Oracle数据库查询的理解...

    数据库面试题4 oracle笔试 oracle例题

    在Oracle数据库的使用中,SQL语句的性能优化至关重要,尤其是在处理大规模数据时。优化SQL语句能够显著提升系统的响应速度,提高系统的可用性和效率。以下是一些关于SQL语句性能调整的重要原则和注意事项: 1. **IS...

    oracle限定查询和排序

    ### Oracle限定查询与排序知识点详解 #### 一、Oracle中的条件查询 在Oracle数据库中,进行数据查询时,经常会遇到需要根据特定条件筛选数据的情况。这些条件查询主要通过`WHERE`子句来实现。 ##### 1. 基本条件...

    oracle函数大全中文api文档

    "Oracle函数大全中文API文档"是一个非常实用的资源,它提供了对Oracle数据库所有内置函数的详尽解释,帮助开发者和DBA快速理解和使用这些函数。 1. **日期与时间函数**: Oracle提供了处理日期和时间的大量函数,...

    oracle通过sql实现字符串转数字oracle函数

    在Oracle数据库中,将字符串转换为数字是一项常见的操作,特别是在处理包含数字的字符串列时,可能需要进行数值计算或按照数值大小进行排序。本篇文章将深入探讨如何在SQL查询中利用Oracle提供的函数来实现这一目标...

    Oracle企业面试题集锦

    - `NULL`值的处理,如正确排序和过滤。 - 选择合适的连接方式和数据类型。 ### Oracle中的段、区和数据块 - 数据块是Oracle数据库的基本存储单位。 - 区是由连续的数据块组成的,属于同一个段。 - 段是属于同一...

    ORACLE数据库及SQL语言考试题一含答案.pdf

    4. 索引:对数据库表中一列或多列的值进行排序的一种结构,使用索引可快速访问数据库表中的特定信息。索引不论逻辑上和物理上都与相关的表的数据无关,索引需要独立的存储空间,所以索引在创建之初就需要设置对应的...

Global site tag (gtag.js) - Google Analytics