org.jarbframework.utils.JdbcUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jarb-utils Show documentation
Show all versions of jarb-utils Show documentation
Provides common utilities
package org.jarbframework.utils;
import java.sql.Connection;
import java.sql.SQLException;
import javax.sql.DataSource;
/**
* Java Database Connectivity (JDBC) utility class.
* @author Jeroen van Schagen
* @since 08-05-2011
*/
public final class JdbcUtils {
/** Utility class, do not instantiate. */
private JdbcUtils() {
}
/**
* Open a data source connection and provide callback functionality
* on that connection. After the callback has been invoked, the newly
* created connection will be closed.
* @param type of object returned by callback
* @param dataSource the data source that we should use
* @param callback the callback functionality being invoked
* @return result of the callback, if any
*/
public static T doWithConnection(DataSource dataSource, JdbcConnectionCallback callback) {
Connection connection = null;
try {
connection = dataSource.getConnection();
return callback.doWork(connection);
} catch (SQLException e) {
throw new RuntimeException(e);
} finally {
closeQuietly(connection);
}
}
/**
* Close the connection, whenever it isn't {@code null}, and
* wrap any SQL exceptions into a runtime exception.
* @param connection our connection to close
*/
public static void closeQuietly(Connection connection) {
try {
if (connection != null) connection.close();
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
/**
* Commits the connection whenver auto commit has been disabled.
* @param connection our connection to commit
*/
public static void commitSafely(Connection connection) {
try {
if (!connection.getAutoCommit()) connection.commit();
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy