All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.wizarius.orm.database.connection.DBConnection Maven / Gradle / Ivy

package com.wizarius.orm.database.connection;

import lombok.extern.slf4j.Slf4j;

import java.io.Closeable;
import java.sql.*;
import java.util.concurrent.*;

/**
 * Created by Vladyslav Shyshkin on 12.11.17.
 */
@SuppressWarnings({"UnusedReturnValue", "unused"})
@Slf4j
public class DBConnection implements Closeable {
    private final ExecutorService executor = Executors.newCachedThreadPool();
    private final DBConnectionPool pool;
    private final Connection connection;
    private PreparedStatement preparedStatement;
    private Statement statement;

    public DBConnection(Connection connection, DBConnectionPool pool) {
        this.connection = connection;
        this.pool = pool;
    }

    /**
     * Create prepare statement
     *
     * @param sql sql to prepare statement
     * @return prepare statement
     * @throws SQLException on unable to create prepared statement
     */
    public PreparedStatement createPrepareStatement(String sql) throws SQLException {
        preparedStatement = connection.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
        return preparedStatement;
    }

    /**
     * Execute prepare statement
     *
     * @return prepare statement execution result
     * @throws SQLException on unable to execute prepared statement
     */
    public ResultSet executePrepareStatement() throws SQLException {
        return preparedStatement.executeQuery();
    }

    /**
     * Create statement
     *
     * @return statement
     * @throws SQLException on unable to create statement
     */
    private Statement createStatement() throws SQLException {
        statement = connection.createStatement();
        return statement;
    }

    /**
     * Execute statement sql query
     *
     * @param sql query to execute
     * @return result set
     * @throws SQLException on unable to execute query
     */
    public ResultSet executeSqlQuery(String sql) throws SQLException {
        return createStatement().executeQuery(sql);
    }

    /**
     * Execute statement query
     *
     * @param sql sql to execute
     * @throws SQLException on unable to execute query
     */
    public boolean executeQuery(String sql) throws SQLException {
        return createStatement().execute(sql);
    }

    /**
     * Execute query
     *
     * @param sql sql to execute
     * @return result of execution
     * @throws SQLException on unable to execute sql query
     */
    public long executeQueryWithKey(String sql) throws SQLException {
        Statement statement = createStatement();
        statement.execute(sql, Statement.RETURN_GENERATED_KEYS);
        ResultSet rs = statement.getGeneratedKeys();
        long productId = 0;
        if (rs.next()) {
            productId = rs.getLong(1);
        }
        return productId;
    }

    /**
     * Connection
     *
     * @return sql connection
     */
    public Connection getConnection() {
        return connection;
    }

    /**
     * Start transaction
     *
     * @throws SQLException on unable to start transaction
     */
    public void startTransaction() throws SQLException {
        // if set true, commit method will be called
        connection.setAutoCommit(false);
    }

    /**
     * End transaction
     *
     * @throws SQLException on unable to commit
     */
    public void commitTransaction() throws SQLException {
        connection.commit();
    }

    /**
     * Rollback transaction
     *
     * @throws SQLException on unable to execute
     */
    public void rollbackTransaction() throws SQLException {
        connection.rollback();
    }

    /**
     * Close
     */
    @Override
    public void close() {
        clearResources();
        pool.releaseConnection(this);
    }

    /**
     * Clear connections
     */
    private void clearResources() {
        try {
            if (preparedStatement != null && !preparedStatement.isClosed()) {
                preparedStatement.close();
            }
        } catch (SQLException e) {
            log.error("Unable to close prepare statement " + e.getMessage(), e);
        }
        try {
            if (statement != null && !statement.isClosed()) {
                statement.close();
            }
        } catch (SQLException e) {
            log.trace("Unable to close statement " + e.getMessage(), e);
        }
        try {
            if (statement != null && !statement.isClosed() && statement.getResultSet() != null && !statement.getResultSet().isClosed()) {
                statement.getResultSet().close();
            }
        } catch (SQLException e) {
            log.error("Unable to close result set. " + e.getMessage(), e);
        }
        try {
            if (!connection.getAutoCommit()) {
                //rollbackTransaction to discard pending transaction changes
                connection.rollback();
                connection.setAutoCommit(true);
            }
        } catch (SQLException e) {
            log.error("Unable to set auto commitTransaction to true. " + e.getMessage(), e);
        }
    }


    /**
     * Check if is connection connected
     *
     * @param seconds timeout seconds
     * @return true if connected
     */
    boolean checkConnection(int seconds) {
        Callable task = () -> {
            final String CHECK_SQL_QUERY = "SELECT 1";
            try {
                PreparedStatement statement = createPrepareStatement(CHECK_SQL_QUERY);
                if (!statement.isClosed()) {
                    statement.execute();
                }
                return true;
            } catch (SQLException | NullPointerException e) {
                log.error("Unable to execute query " + CHECK_SQL_QUERY + " . " + e.getMessage(), e);
            } catch (Exception e) {
                log.error("Another exception in query execution" + CHECK_SQL_QUERY + " . " + e.getMessage(), e);
            }
            return false;
        };
        Future future = executor.submit(task);
        try {
            return future.get(seconds, TimeUnit.SECONDS);
        } catch (TimeoutException | InterruptedException | ExecutionException e) {
            log.error("Unable to check connection " + e.getMessage(), e);
            return false;
        } catch (Exception e) {
            log.error("Unable to check connection another exception" + e.getMessage(), e);
            return false;
        } finally {
            clearResources();
            future.cancel(true);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy