小葫芦
2021-09-01 11:00
采纳率: 100%
浏览 84
已结题

正则替换 sql语法 去掉字段中的引号,请大家帮帮我

例如有一条插入语句
insert into table("id","name","remark") values ('1','test','[{"key1":"value1","key2":"value2"}]')
把字段中的引号去掉,替换后 (有多张表,表字段不固定有几个)
insert into table(id,name,remark) values ('1','test','[{"key1":"value1","key2":"value2"}]')

我的思路是 取 insert 和 values 之间的所有引号,但是这个不知道怎么写,有没有知道的

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 邀请回答

4条回答 默认 最新

  • CSDN专家-showbo 2021-09-01 11:24
    最佳回答

    题主试试,测试正常。有帮助或启发麻烦点个采纳【本回答右上角】,谢谢~~

    img

    import java.util.regex.Pattern;
    import java.util.regex.Matcher;
    class t{
      public static void main(String[]args){
          String s="insert into table(\"id\",\"name\",\"remark\") values ('1','test','[{\"key1\":\"value1\",\"key2\":\"value2\"}]')\n"+
          "insert into table(\"id\",\"name\",\"remark\") values ('1','test','[{\"key1\":\"value1\",\"key2\":\"value2\"}]')\n"+
          "insert into table(\"id\",\"name\",\"remark\") values ('1','test','[{\"key1\":\"value1\",\"key2\":\"value2\"}]')\n";
          
          System.out.println(s);
          System.out.println("--------------------");
    
          String pattern = "\\([^\\)]+\\)\\s*values";
          Pattern p = Pattern.compile(pattern, Pattern.CASE_INSENSITIVE);
          Matcher m = p.matcher(s);
          StringBuffer sb = new StringBuffer();
          while (m.find())
          {
                String key = m.group(0);
                m.appendReplacement(sb, key.replace("\"",""));
          }
          m.appendTail(sb);
          s=sb.toString();
          System.out.println(sb.toString());
      }
    }
    
    评论
    解决 1 无用
    打赏 举报
查看更多回答(3条)

相关推荐 更多相似问题