--有数字会显示出来
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;
执行结果:**人