Oracle数据库REPLACE+SUBSTR用*对姓名/身份证进行脱敏处理


上篇出了怎么通过身份证计算年龄,比较有用,这篇出再稽核数据的时候对名字和证件进行脱敏处理。

第一种:对姓名进行脱敏处理,使用*代替姓名中的第二个字。

select replace('张三',SUBSTR('张三',2,1),'*') as name FROM DUAL;

--REPLACE 替换(原字符,需要替换的位置和长度,要替换的字符);

--SUBSTR(原字符,从1开始数,数到第二个字,长度1)

 

 第二种情况,对身份证的第四位开始,替换3位。

select replace('123456199811165527',SUBSTR('123456199811165527',4,3),'***') as cert_num FROM DUAL;

 

 延申,对身份证后四位替换为*

select replace('123456199811165527',SUBSTR('123456199811165527',15,4),'****') as cert_num FROM DUAL;

 

 

可以拓展,各种用符号代替。

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM