• 一个$符,差点把我搞死了


    说明:在我使用update进行数据修改的时候,破天荒的有个字段的数据开头是$符的,这就尴尬了,jdk竟然把它当做是正则表达式来处理的,所以报错的结果是:java.lang.IndexOutOfBoundsException: No group 2

       查了资料,非常感谢@单眼皮的猪 提供的解决方法:

    在使用String.replaceAll(regex,replacement)方法时,当replacement出现反斜杠或美元符号$时会出现java.lang.IndexOutOfBoundsException No group的异常,查看api文档时说是可以用java.util.regex.Matcher.quoteReplacement(String s)先过滤,但是此方法是1.5才出现的

    如果是1.4
    手写以下方法即可实现

      1.   
      2.     public static String quoteReplacement(String s) {  
      3.         if ((s.indexOf('\') == -1) && (s.indexOf('$') == -1))  
      4.             return s;  
      5.         StringBuffer sb = new StringBuffer();  
      6.         for (int i=0; i<s.length(); i++) {  
      7.             char c = s.charAt(i);  
      8.             if (c == '\') {  
      9.                 sb.append('\'); sb.append('\');  
      10.             } else if (c == '$') {  
      11.                 sb.append('\'); sb.append('$');  
      12.             } else {  
      13.                 sb.append(c);  
      14.             }  
      15.         }  
      16.         return sb.toString();  
      17.     }  
      18. 当然了我用了一个更简单粗暴的方法,就是将数据库中的$符,直接删除
    梦想这东西和经典一样,永远不会随时间而褪色,反而更加珍贵!
  • 相关阅读:
    Gradle 配置国内镜像
    Spring_Boot 简单例子
    IDEA中代码不小心删除,或者改了半天想回退到某个特定时间怎么办?
    Java 装饰模式
    Spring中 aop的 xml配置(简单示例)
    Spring使用@AspectJ开发AOP(零配置文件)
    Redis 的简单运算
    Redis 安装 与 使用
    touch-action属性引起的探索
    select下拉框的探索(<option></option>标签中能嵌套使用其它标签吗)
  • 原文地址:https://www.cnblogs.com/haoxiu1004/p/7737295.html
Copyright © 2020-2023  润新知