godwilling 2008-06-15 15:12
浏览 370
已采纳

正则表达式替换SQL语句中的字段

我想用正则表达式匹配一个insert的SQL语句,能够自动地将变量赋给对应的字段,比如
SQL=“insert into table(item1,item2,item3) values(:item1,:item2,:item3)”
map.put(item1,"111")
map.put(item2,"222")
map.put(item3,"333")

我想用正则表达式自动的将SQL语句中的:item1,:item2,:item3替换成map中对应的“111”,"222","333"

请问我该怎么写正则表达式的匹配语句和 对应的方法。

  • 写回答

4条回答 默认 最新

  • llade163 2008-06-16 00:47
    关注

    搞错了。忘了加上非捕获组。刚才代码未验证。呵呵,偷懒了。
    [code="java"]String SQL="insert into table(item1,item2,item3) values(:item1,:item2,:item3)";
    Map map = new HashMap();
    map.put("item1","111");
    map.put("item2","222");
    map.put("item3","333");

            Pattern p=Pattern.compile("(?::)(\\w+)(?:\\b)");   
            Matcher m=p.matcher(SQL);   
            StringBuffer result=new StringBuffer();   
            while (m.find()) {   
                String key=m.group(1);   
                m.appendReplacement(result,(String)map.get(key));   
            }   
            m.appendTail(result);   
            String resultSql=result.toString();
            System.out.println(resultSql);[/code]
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算