判断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

判断ORACLE是否存在数字

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

判断ORACLE是否存在数字

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

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是否存在数字

上一篇:PG主程序模块(Main)——数据库PostgreSQL入口


下一篇:MySQL 8.0(8.0.17+) Clone-plugin整理