引用场景:
问题1:从一个表中查询出数据,然后插入另外一个表。表中某字段attr_value的值含有 反斜杠,例如:name:=ct00$cphBaseCond$cmd,name2:=ct00$cphBaseCond$cmd
分析:
- 查询出来的数据存储到java的String变量,不会自动转义为,因此需要手动转义
- 转义的方法可以用replace和replaceAll两种方法,这里需要注意两种方法对转义字符的差异。
- replaceAll会对输入的字符串增加一次转义,用于处理正则表达式的转换。
实现方法对比如下:
package cn.ltdi;public class TranslateSQLCharacter { // 使用replaceAll 替换 反斜杠 public String TranslateString2SQLbyreplaceAll(String exeSQL) { //在参数专递过程进行了一次转义,在正则表达式的处理过程又进行了一次转义 String objectAttr_new = exeSQL.replaceAll("",""); return objectAttr_new; } // 使用replace 替换 反斜杠 public String TranslateString2SQLbyreplace(String exeSQL) { String objectAttr_new = exeSQL.replace("",""); return objectAttr_new; } public static void main(String []args){ TranslateSQLCharacter tsc = new TranslateSQLCharacter(); String objectAttr = "name:=ct00$cphBaseCond$cmd,name2:=ct00$cphBaseCond$cmd"; System.out.println(objectAttr); String objectAttrNew = tsc.TranslateString2SQLbyreplaceAll(objectAttr); System.out.println(objectAttrNew); objectAttrNew = tsc.TranslateString2SQLbyreplace(objectAttr); System.out.println(objectAttrNew); }}
执行结果:
name:=ct00$cphBaseCond$cmd,name2:=ct00$cphBaseCond$cmd
name:=ct00$cphBaseCond$cmd,name2:=ct00$cphBaseCond$cmd
name:=ct00$cphBaseCond$cmd,name2:=ct00$cphBaseCond$cmd
Process finished with exit code 0
![b9fb33696a62c072e0ee6e7cdff106c3.png](https://img-blog.csdnimg.cn/img_convert/b9fb33696a62c072e0ee6e7cdff106c3.png)