0

我正在为 PostgreSQL 使用 JDBC 驱动程序,我想调用存储过程。

假设我有一个调用存储过程的方法,如下所示:

public void callProcedure(int someValue)    {

    Connection con = null;
    try {
        con = connectionPool.getConnection();

        CallableStatement st = con.prepareCall("{ call some_procedure(?) }");
        st.setInt(1, someValue);
        st.execute();
        st.close();
    }
    catch (SQLException e)  {
        System.out.println(e.getMessage());
    }
    finally     {
        if (con != null) {
            try { con.close(); } // assure connection "goes" back to the pool
            catch (SQLException e)  { }
        }
    }
}

现在让我们假设这个方法callProcedure可能被调用数百万次。我的问题是:

(1.) 如果我在类的构造函数和构造函数中创建连接会更好(性能方面)prepare_the_Call,所以像这样:

CallableStatement st;

public Constructor() {
   Connection con = connectionPool.getConnection();
   st = con.prepareCall("{call some_procedure(?)}");
}

然后在方法内部执行:

   public void callProcedure(int someValue) {
    try {
        st.setInt(1, someValue);
        st.execute();
        st.close();
    }
    catch (SQLException e)  {
        System.out.println(e.getMessage());
    }
    finally     {
        if (con != null) {
            try { con.close(); } // assure connection "goes" back to the pool
            catch (SQLException e)  { }
        }
    }
    }

close(2.)执行语句后总是对连接有意义吗?还是我应该让它保持打开状态?据我了解,关闭它会将连接返回到连接池,以便其他人可以使用它。那是对的吗?

4

1 回答 1

1
  1. 将该语句放在构造函数中不会导致性能提高。您只是在对象生命周期的不同点创建连接。

  2. 你是对的,关闭连接会立即将它返回到连接池,而不是等待它自动发生。最好的做法是这样做。

于 2013-10-06T02:20:52.050 回答