Java – did I close this Oracle pool connection correctly?
I tried to connect to my web application using a pool in Java I'm using Oracle database. Here's my code:
public class DatabaseHandler { static private Connection m_database = null; static private OracleConnectionPoolDataSource pooledSource = null; /** * Attempts to open an Oracle database located at the specified serverName and port. * @param serverName Address of the server. * @param portNumber Port to connect to. * @param sid SID of the server. * @param userName Username to login with. * @param password Password to login with. * @throws WebApplicationException with response code 500 Internal Server Error. */ static public void openDatabase(String userName,String password,String serverName,int portNumber,String sid) throws WebApplicationException { try { // Load the JDBC driver String driverName = "oracle.jdbc.driver.OracleDriver"; Class.forName(driverName); // Create a connection to the database String url = "jdbc:oracle:thin:@" + serverName + ":" + portNumber + ":" + sid; pooledSource = new OracleConnectionPoolDataSource(); pooledSource.setUser(userName); pooledSource.setURL(url); pooledSource.setPassword(password); m_database = pooledSource.getConnection(); } catch (ClassNotFoundException e) { // Could not find the database driver throw new WebApplicationException(Response.Status.INTERNAL_SERVER_ERROR); } catch (sqlException e) { // Could not connect to the database throw new WebApplicationException(Response.Status.INTERNAL_SERVER_ERROR); } } /** * Attempts to execute the specified sql query. * @throws WebApplicationException with a response code of Bad Request * if the query is invalid sql. */ static public ResultSet makeQuery(String query) throws WebApplicationException { ResultSet rs = null; if (m_database != null) { try { Statement stmt = m_database.createStatement(); rs = stmt.executeQuery(query); } catch (sqlException e) { // invalid query System.out.println(query); throw new WebApplicationException(Response.Status.BAD_REQUEST); } } return rs; } /** * Attempts to close the database. * @throws WebApplicationException with a response code of 500 Server error */ static public void closeDatbase() throws WebApplicationException { try { m_database.close(); pooledSource.close(); } catch(sqlException e) { throw new WebApplicationException(Response.Status.INTERNAL_SERVER_ERROR); } } }
I do this in eclipse, and I issue a warning, pooledsource Close() is deprecated I've never used a pooled connection before. I just want to make sure everything I'm doing is right Is there a better way to turn off Oracle pooled resources?
Solution
The deprecated method means that it should not be used In future releases, the close () method can be completely cleared I suggest deleting pooledsource close().
In addition, I recommend not having a static instance of connection and datasource, because you need connection requests and do not remain active throughout the application Always close the resultset first, then the connection, and ensure closure by adding them to the finally block