判断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;
执行结果:**人
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了