oracle通过正则验证香港、澳门、台湾的身份证和护照

这篇博客介绍了如何利用Oracle的正则表达式验证香港、台湾和澳门地区的身份证和护照号码。香港身份证由1个或2个英文字母、6个数字和1个括号内的数字或字母"A"组成;台湾身份证由1个字母和9个数字组成;澳门身份证则是8位数字,首位仅限1、5、7。博客提供了对应的Oracle SQL查询语句来识别不同地区的证件类型。

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

台湾的:1个英文+9个数字
[A-Z][0-9]{9}
香港的:一个英文+6个数字+(一个校验码0~9或A)
[A-Z][0-9]{6}\([0-9A]\)
澳门的:第一位1、5、7,后面7个数字,最后带括号的一位校验码
[157][0-9]{6}\([0-9]\)
护照的:因私普通护照号码格式有:14/15+7位数,G+8位数;因公普通的是:P.+7位数;
公务的是:S.+7位数 或者 S+8位数,以D开头的是外交护照.D=diplomatic
^1[45][0-9]{7}|G[0-9]{8}|P[0-9]{7}|S[0-9]{7,8}|D[0-9]+$
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值