一、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中区分三网查询手机号的两种方式,可能正则表达式可以进行优化,有需要的小伙伴可以参考一下。