zoukankan      html  css  js  c++  java
  • Oracle中中文、数字,英文混杂形式的字段进行排序的方法

    http://blog.csdn.net/p451933505/article/details/9272257

    对Oracle中中文、数字、英文混杂形式的字段进行排序的方法:

    例如:

    1. order by NLSSORT(字段名,'NLS_SORT = SCHINESE_PINYIN_M'), to_number(translate(字段名, '0123456789' || 字段名, '0123456789'))   

    NLSSORT() 函数:

    可以使用NLSSORT()函数可以改变Oralce 对汉字的排序规则,排序规则如下(前三条对简体中文进行排序,后两条对繁体中文进行排序):

    1. SCHINESE_RADICAL_M

        简体中文按照第一顺序是“部首”、第二顺序是“笔画数”进行排序。

    2. SCHINESE_STROKE_M

        简体中文按照第一顺序“笔画数”、是第二顺序是“部首”进行排序。

    3. SCHINESE_PINYIN_M

        简体中文按照拼音进行排序。上例中即对简体汉字按照拼音进行排序。

    4. TCHINESE_RADICAL_M

        繁体中文按照第一顺序是“部首”、第二顺序是“笔画数”进行排序。

    5. TCHINESE_STROKE_M

        繁体中文按照第一顺序是“笔画数”、第二顺序是“部首”进行排序。 

    TRANSLATE() 函数:

    用法:将char中出现在from中的每个字符替换为to中的相应字符,若from比to字符串长,那么在from中比to中多出的字符将会被删除。三个参数中有一个是空,返回值也将是空值。

     

    1. select TRANSLATE('例1213','0123456789'||'例1213','0123456789') as RESULT from dual;  
    2.   RESULT  
    3. ------------   
    4.   1213  

    分析:该语句要将 char--'例1213' 中出现在 from--'0123456789例1213' 中的字符替换为 to--'0123456789' 中的字符,根据 from、to 的对应关系,将 char 中的 0替换成0、1替换成1、...9替换成9,即 char 中的数字不变,又 from 比 to 长,则 from 中比 to 中多出的字符将被删除,即删除 char 中的汉字。

  • 相关阅读:
    关于委托的一篇不错的文章(C# 中的委托和事件)
    李建忠老师的《.net框架程序设计(修订版)》电子书下载地址,超级推荐
    普通无线路由变成纯AP模式
    CLR到底是什么?是怎么工作的?
    HTTP协议的三个问题
    桌面战争——揭秘中国互联网的里程碑之战
    B2C这点事儿
    不用baidu,不用google,你有bing啊
    让.net程序脱离.NET Framework在Linux下运行
    哥乃一介光棍
  • 原文地址:https://www.cnblogs.com/oraclesea/p/5472682.html
Copyright © 2011-2022 走看看