从一个PreparedStatement复制参数到另一个PreparedStatement

3

I create a new PreparedStatement like this:

PreparedStatement newPs = origPrepStatement.getConnection().prepareStatement("EXPLAIN " + sql);

origPrepStatement也是Preparedstatement类型,它包含参数。 我希望将origPrepStatement中的参数复制到newPs中。 有没有办法做到这一点?


3
请点击这里查看:https://dev59.com/B2445IYBdhLWcg3w0NSu#4691561 - NilsH
很遗憾:-( 我不需要它来调试,我需要它用于其他目的。 - Sanyifejű
1个回答

1

似乎没有简单的解决方案;以下是我笨拙的解决方案

class PreparedStatementParameters implements InvocationHandler {
    Map<Integer, Object> map = new HashMap<>();
    PreparedStatement ps;

    PreparedStatementParameters(PreparedStatement ps) {
        this.ps = ps;
    }

    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        if (method.getName().startsWith("set")) {

        }
        return method.invoke(proxy, args);
    }

    public void copyParameters(PreparedStatement ps) throws SQLException {
        for (Map.Entry<Integer, Object> e : map.entrySet()) {
            ps.setObject(e.getKey(), e.getValue());
        }
    }
}

public class T2 {
    public static void main(String[] args) throws Exception {
        PreparedStatement ps1 = ...
    PreparedStatementParameters ps1params = new PreparedStatementParameters(ps1);
        PreparedStatement ps1Proxy = (PreparedStatement) Proxy.newProxyInstance(null,
                new Class[] { PreparedStatement.class }, new PreparedStatementParameters(ps1));
        ps1Proxy.setString(1, "test");
        ...
        PreparedStatement ps2 = ...
        ps1params.copyParameters(ps2);
    }
}

这里发生了什么? 如果 (method.getName().startsWith("set")) { } - Sanyifejű
在ps1上设置的所有参数都将保存在PreparedStatementParameters中。 - Evgeniy Dorofeev

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接