您的位置 首页 java

java中反斜杠\的两种处理方法对比

引用场景:

问题1:从一个表中查询出数据,然后插入另外一个表。表中某字段attr_value的值含有 反斜杠,例如:name:=ct00\$cphBaseCond\$cmd,name2:=ct00\$cphBaseCond\$cmd

分析:

  1. 查询出来的数据存储到 java 的String变量,\不会自动转义为\\,因此需要手动转义
  2. 转义的方法可以用replace和replaceAll两种方法,这里需要注意两种方法对 转义字符 的差异。
  3. 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);
 }
} 

执行结果:

文章来源:智云一二三科技

文章标题:java中反斜杠\的两种处理方法对比

文章地址:https://www.zhihuclub.com/198829.shtml

关于作者: 智云科技

热门文章

发表回复

您的电子邮箱地址不会被公开。

网站地图