このページを読みました: http://www.javaranch.com/journal/200601/JDBCConnectionPooling.html
Method Scope Connections のアプローチは、私にとって非常に良いようです。しかし、1 つ質問があります。いつ JDBCServlet クラスを初期化しますか? 接続が必要なたびに?接続が必要なときはいつでも電話するだけだと思っていたのでgetConnection()
...
public class JDBCServlet extends HttpServlet {
private DataSource datasource;
public void init(ServletConfig config) throws ServletException {
try {
// Look up the JNDI data source only once at init time
Context envCtx = (Context) new InitialContext().lookup("java:comp/env");
datasource = (DataSource) envCtx.lookup("jdbc/MyDataSource");
}
catch (NamingException e) {
e.printStackTrace();
}
}
private Connection getConnection() throws SQLException {
return datasource.getConnection();
}
public void doGet (HttpServletRequest req, HttpServletResponse res) throws ServletException {
Connection connection=null;
try {
connection = getConnection();
..<do JDBC work>..
}
catch (SQLException sqlException) {
sqlException.printStackTrace();
}
finally {
if (connection != null)
try {connection.close();} catch (SQLException e) {}
}
}
}
}