TRANSLATE 函数

本文探讨了如何使用Oracle SQL中的translate函数进行特定字符替换,以验证和处理手机号码格式,确保其符合预设规范。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

TRANSLATE ( 'string' , 'from_string' , 'to_string' )
【参数】string 原字符串,from_string 待转换的每个字符,to_string 将转换成的每个字符 
【功能】将string中每个包含 from_string 的字符转换成 to_string 中对应位置字符
【例子】
select translate ( 'WUHEN', 'WAN' ,'LB' from dual;

TRANSLATE('WUHEN','WAN','LB')
-----------------------------
LUHE

from_string 为WAN,string为WUHEN,string中的W字符转换为对应的字符 '1';'A'转换为'B',但没有字符A,不做转换;'N'to_string中没有对应需去除,'WUHEN'中的其他字符不变。
W--L
U--U
H--H
E--E
N--
 
【实际应用】
环境:oracle9i
目标:判断手机格式是否正确
sql:
select * from table 
WHERE length (tel)=11 AND 
SUBSTR (tel,1 , 2IN ('13' , '14', '15' ,'18' and 
translate (tel,'$1234567890' , '$'is null
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值