正则表达式替换字符

场景:

       代码中一段生成创建临时表的sql,会将number类型的创建成超过38位最大值,比如number(39,4)。问题原因无法找到,估计是跟数据库有关系,所以现在通过正则查,一但发现有违规数据,就改变。

测试代码:

package snippet;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Snippet {
	public static void main(String[] args) {
		//错误sql
		String a = "create table RepSysNav006_zhangsh(FDETAIL NUMBER(68,2112),FDETAILORSUM NUMBER(40),FKEYCODE CHAR(4))";
		//Pattern pattern = Pattern.compile("(NUMBER[(](39|[4-9][0-9]|\\d{3,})(,\\d+)?[)])");
		//Pattern pattern = Pattern.compile("(NUMBER[(](39|[4-9][0-9]|\\d{3,})(,\\d+)?[)])|(NUMBER[(]\\d+,(39|[4-9][0-9]|\\d{3,})[)])");
		Pattern pattern = Pattern.compile("NUMBER[(]((39|[4-9][0-9]|\\d{3,})(,\\d+)?|\\d+,(39|[4-9][0-9]|\\d{3,}))[)]");
		Matcher matcher = pattern.matcher(a);
		StringBuffer sb = new StringBuffer();
		while(matcher.find()){
			String d= matcher.group().replaceAll("39|[4-9][0-9]|\\d{3,}", "38");
			matcher.appendReplacement(sb, d);
		}
		matcher.appendTail(sb);
		System.out.println(sb.toString());
	}
}

最终代码:

101645_Gk1S_2728642.png

 

转载于:https://my.oschina.net/xueyuanshuai/blog/883682

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值