zoukankan      html  css  js  c++  java
  • 判断ORACLE是否存在数字

    --有数字会显示出来

    select * from gy_jbbm where regexp_substr(jbmc,'[0-9]+') is not null

    --替换字母A-Z

    select replace(translate( upper('23ffAAf3232'),'ABCDEFGHIJKLMNOPQRSTUVWXYZ','A'),'A','')  from dual;

    扩展:

    REGEXP_SUBSTR函数格式如下:

    function REGEXP_SUBSTR(String, pattern, position, occurrence, modifier)

    __srcstr     :需要进行正则处理的字符串

    __pattern    :进行匹配的正则表达式

    __position   :起始位置,从第几个字符开始正则表达式匹配(默认为1)

    __occurrence :标识第几个匹配组,默认为1

    __modifier   :模式('i'不区分大小写进行检索;'c'区分大小写进行检索。默认为'c'。)

    select regexp_substr('1|3767|3767|3766|0', '[^|]+', 1, 1),
           regexp_substr('1|3767|3767|3766|0', '[^|]+', 1, 2)cell1,
           regexp_substr('1|3767|3767|3766|0', '[^|]+', 1, 3)cell2,
           regexp_substr('1|3767|3767|3766|0', '[^|]+', 1, 4)cell3,
           regexp_substr('1|3767|3767|3766|0', '[^|]+', 1, 5)
    from dual

    select regexp_substr('1-3404-3399-3420-0', '[^-]+', 1, 1) t1,
           regexp_substr('1-3404-3399-3420-0', '[^-]+', 1, 2) t2,
           regexp_substr('1-3404-3399-3420-0', '[^-]+', 1, 3) t3,
           regexp_substr('1-3404-3399-3420-0', '[^-]+', 1, 4) t4,
           regexp_substr('1-3404-3399-3420-0', '[^-]+', 1, 5) t5,
           regexp_substr('1-3404-3399-3420-0', '[^-]+', 1, (length('1-3404-3399-3420-0')-length(regexp_replace('1-3404-3399-3420-0','-','' )))+1) t5--取最后一位
    from dual

     -----------------------------------假装是个分割线-------------------------------------------------

    translate

    translate(string,from_str,to_str);

    解释:返回将(所有出现的)from_str中的每个字符替换为to_str中的相应字符以后的string。TRANSLATE 是 REPLACE 所提供的功能的一个超集。如果 from_str 比 to_str 长,那么在 from_str 中而不在 to_str 中的额外字符将从 string 中被删除,因为它们没有相应的替换字符。to_str 不能为空。Oracle 将空字符串解释为 NULL,并且如果TRANSLATE 中的任何参数为NULL,那么结果也是 NULL。

    常用的场景:

    1. 将数字转换为9,其他的大写字母转换为X,然后返回。SELECTTRANSLATE('2KRW229','0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ','9999999999XXXXXXXXXXXXXXXXXXXXXXXXXX')   "example"FROM DUAL;

    得到的结果是: 9XXX999

    2.将数字保留,其他的大写字母移除

    SELECT TRANSLATE('2KRW229','0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ','0123456789') "Translate example"FROM DUAL

    得到的结果是: 2229

    3.字段处理是按照字符来处理的,不是按照字节来处理,如果to_str的字符数比from_str多的话,多出来的字符数也不会被用到,也不会报异常。

    SELECT TRANSLATE('我是中国人,我爱中国', '中国', 'China') "Translate example" FROM DUAL

    执行结果:我是Ch人,我爱Ch

    4. 如果from_string的字符数大于to_string,那么多出的字符会被移除,也就是ina三个字符会从char参数中移除,当然区分大小写啦

    SELECT TRANSLATE('I am Chinese, I love China', 'China', '中国') "Translate example" FROM DUAL

    执行结果:I m 中国ese, I love 中国

    5. 如果第二个参数是空字符串的话,整个返回null。

    SELECT TRANSLATE('2KRW229','0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ','') "License"FROM DUAL

    执行结果 是空

    6. 在银行转账的时候经常看到很多字眼做了脱敏处理。

    SELECT TRANSLATE('中国人',substr('中国人',1,length('中国人') - 1),rpad('*',length('中国人'),'*')) "License"     FROM DUAL;

    执行结果:**人

  • 相关阅读:
    Oracle从入门到精通(笔记)
    MongoDB教程(笔记)
    深入浅出Oracle:DBA入门、进阶与诊断案例(读书笔记2)
    深入浅出Oracle:DBA入门、进阶与诊断案例(读书笔记1)
    获取本周、本季度、本月、上月的开始日期、结束日期
    TortoiseSVN新人使用指南
    Eclipse创建java web工程
    supersock问题
    UDP错误10054:远程主机强迫关闭了一个现有的连接
    【转】javascript深入理解js闭包
  • 原文地址:https://www.cnblogs.com/JIKes/p/14202523.html
Copyright © 2011-2022 走看看