/*
* Copyright 2010-2017 Boxfuse GmbH
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.flywaydb.core.internal.util.jdbc;
import org.flywaydb.core.api.FlywayException;
import org.flywaydb.core.internal.dbsupport.FlywaySqlException;
import org.flywaydb.core.internal.util.logging.Log;
import org.flywaydb.core.internal.util.logging.LogFactory;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
/**
* Utility class for dealing with jdbc connections.
*/
public class JdbcUtils {
private static final Log LOG = LogFactory.getLog(JdbcUtils.class);
/**
* Prevents instantiation.
*/
private JdbcUtils() {
//Do nothing
}
/**
* Opens a new connection from this dataSource.
*
* @param dataSource The dataSource to obtain the connection from.
* @return The new connection.
* @throws FlywayException when the connection could not be opened.
*/
public static Connection openConnection(DataSource dataSource) throws FlywayException {
try {
Connection connection = dataSource.getConnection();
if (connection == null) {
throw new FlywayException("Unable to obtain Jdbc connection from DataSource");
}
return connection;
} catch (SQLException e) {
throw new FlywaySqlException("Unable to obtain Jdbc connection from DataSource", e);
}
}
/**
* Safely closes this connection. This method never fails.
*
* @param connection The connection to close.
*/
public static void closeConnection(Connection connection) {
if (connection == null) {
return;
}
try {
connection.close();
} catch (SQLException e) {
LOG.error("Error while closing Jdbc connection", e);
}
}
/**
* Safely closes this statement. This method never fails.
*
* @param statement The statement to close.
*/
public static void closeStatement(Statement statement) {
if (statement == null) {
return;
}
try {
statement.close();
} catch (SQLException e) {
LOG.error("Error while closing Jdbc statement", e);
}
}
/**
* Safely closes this resultSet. This method never fails.
*
* @param resultSet The resultSet to close.
*/
public static void closeResultSet(ResultSet resultSet) {
if (resultSet == null) {
return;
}
try {
resultSet.close();
} catch (SQLException e) {
LOG.error("Error while closing Jdbc resultSet", e);
}
}
}