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

正则表达式替换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条)

报告相同问题?