说明:在我使用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
手写以下方法即可实现
- public static String quoteReplacement(String s) {
- if ((s.indexOf('\') == -1) && (s.indexOf('$') == -1))
- return s;
- StringBuffer sb = new StringBuffer();
- for (int i=0; i<s.length(); i++) {
- char c = s.charAt(i);
- if (c == '\') {
- sb.append('\'); sb.append('\');
- } else if (c == '$') {
- sb.append('\'); sb.append('$');
- } else {
- sb.append(c);
- }
- }
- return sb.toString();
- }
- 当然了我用了一个更简单粗暴的方法,就是将数据库中的$符,直接删除