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条)

报告相同问题?

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站