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

正则替换 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());
      }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 9月9日
  • 已采纳回答 9月1日
  • 修改了问题 9月1日
  • 修改了问题 9月1日
  • 展开全部

悬赏问题

  • ¥15 cgictest.cgi文件无法访问
  • ¥20 删除和修改功能无法调用
  • ¥15 kafka topic 所有分副本数修改
  • ¥15 小程序中fit格式等运动数据文件怎样实现可视化?(包含心率信息))
  • ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
  • ¥40 串口调试助手打开串口后,keil5的代码就停止了
  • ¥15 电脑最近经常蓝屏,求大家看看哪的问题
  • ¥60 高价有偿求java辅导。工程量较大,价格你定,联系确定辅导后将采纳你的答案。希望能给出完整详细代码,并能解释回答我关于代码的疑问疑问,代码要求如下,联系我会发文档
  • ¥50 C++五子棋AI程序编写
  • ¥30 求安卓设备利用一个typeC接口,同时实现向pc一边投屏一边上传数据的解决方案。