Java中区分三大运营商来查询对应的手机号列表

一、Java使用正则表达式区分查询:

判断运营商主要是以手机号前三位或前四位进行判定,下面整个代码过程包含了各运营商手机标识,判断的正则表达式,以及测试代码,可以按照自己的实际需求进行更改

import java.util.regex.Pattern;

/**
 * @author sbp
 * @description: 三大运营商手机号区分
 */
public class OperatorUtils {
    /**
     * 中国移动号码正则
     * 139、138、137、136、135、134、147、150、151、152、157、158、159、178、182、183、184、187、188、198、195
     * 虚拟运营商号段: 1703、1705、1706、165
     **/
    private static final String MOBILE_PATTERN = "(^1(3[4-9]|47|5[0-27-9]|65|78|8[2-478]|98)\\d{8}$)|(^170[356]\\d{7}$)";

    /**
     * 中国电信号码正则
     * 133、149、153、173、177、180、181、189、199、191
     * 虚拟运营商号段: 162、1700、1701、1702
     **/
    private static final String TELECOM_PATTERN = "(^1(33|49|53|62|7[37]|8[019]|9[19])\\d{8}$)|(^170[012]\\d{7}$)";

    /**
     * 中国联通号码正则
     * 130、131、132、155、156、185、186、145、175、176、166、140
     * 虚拟运营商号段: 171、1707、1708、1709、167
     **/
    private static final String UNICOM_PATTERN = "(^1(3[0-2]|4[05]|5[56]|6[67]|7[156]|8[56])\\d{8}$)|(^170[7-9]\\d{7}$)";

    public static String isOperator(String phone){

        if(Pattern.matches(MOBILE_PATTERN, phone)){
            return "中国移动";
        }
        if(Pattern.matches(TELECOM_PATTERN, phone)){
            return "中国联通";
        }
        if(Pattern.matches(UNICOM_PATTERN, phone)){
            return "中国电信";
        }
        return "未知运营商";
    }

    public static void main(String[] args) {
        System.out.println(isOperator("18215321***"));
        System.out.println(isOperator("17614501***"));
        System.out.println(isOperator("15387473***"));
    }
}

运行结果:
18215321***:中国移动
17614501***:中国电信
15387473***:中国联通

二、通过sql语句直接在数据库查询

MySQL中使用正则表达式一般是使用REGEXP函数进行查询:
使用方式见下面语句,对手机号判断的可以直接搬用

select fm.id, 
	   fm.phone,
	   case 
	     //移动手机号区分
		 WHEN TRIM(fm.phone) REGEXP '^13[5-9]|^134[0-8]|^15[012789]|^18[23478]|^178|^14[78]|^170[356]|^198|^1440' THEN '中国移动'
         //联通手机号区分
         WHEN TRIM(fm.phone) REGEXP '^13[0-2]|^145|^15[56]|^176|^1704|^1707|^1708|^1709|^171|^18[56]' THEN '中国联通'
         //电信手机号区分
         WHEN TRIM(fm.phone) REGEXP '^133|^153|^1700|^1701|^1702|^177|^173|^18[019]' THEN '中国电信'
		 ELSE '未知运营商'
       END AS provider
from ym_family_member fm 
//通过正则表达式筛选符合手机号格式的数据
where fm.phone REGEXP '^1([358][0-9]|4[579]|66|7[0135678]|9[89])[0-9]{8}$'
 limit 0, 4

以上就是Java代码和MySQL中区分三网查询手机号的两种方式,可能正则表达式可以进行优化,有需要的小伙伴可以参考一下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值