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

org.jfleet.mysql.MySqlTransactionPolicy Maven / Gradle / Ivy

Go to download

JFleet loads data mapped as JPA into DB with alternate and fast way from JPA

There is a newer version: 0.6.8
Show newest version
/**
 * Copyright 2022 Jerónimo López Bezanilla
 *
 * 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.jfleet.mysql;

import java.sql.Connection;
import java.sql.SQLException;

import org.jfleet.JFleetException;

interface MySqlTransactionPolicy {

    static MySqlTransactionPolicy getTransactionPolicy(Connection connection, boolean autocommit,
            boolean errorOnMissingRow) throws SQLException {
        if (autocommit) {
            return new BatchTransaction(connection, errorOnMissingRow);
        }
        return new LongTransaction(errorOnMissingRow);
    }

    void commit(int processed, long updatedInDB) throws SQLException, JFleetException;

    void close() throws SQLException;

    class LongTransaction implements MySqlTransactionPolicy {

        private boolean errorOnMissingRow;

        LongTransaction(boolean errorOnMissingRow) {
            this.errorOnMissingRow = errorOnMissingRow;
        }

        @Override
        public void commit(int processed, long updatedInDB) throws SQLException, JFleetException {
            if (errorOnMissingRow && processed != updatedInDB) {
                throw new JFleetException(
                        "Missed rows, processed by JFleet: " + processed + ", loaded in DB: " + updatedInDB);
            }
        }

        @Override
        public void close() throws SQLException {

        }

    }

    class BatchTransaction implements MySqlTransactionPolicy {

        private final Connection connection;
        private final boolean autocommit;
        private boolean errorOnMissingRow;

        BatchTransaction(Connection connection, boolean errorOnMissingRow) throws SQLException {
            this.connection = connection;
            this.errorOnMissingRow = errorOnMissingRow;
            this.autocommit = connection.getAutoCommit();
            this.connection.setAutoCommit(false);
        }

        @Override
        public void commit(int processed, long updatedInDB) throws SQLException, JFleetException {
            if (errorOnMissingRow && processed != updatedInDB) {
                this.connection.rollback();
                throw new JFleetException(
                        "Missed rows, processed by JFleet: " + processed + ", loaded in DB: " + updatedInDB);
            }
            this.connection.commit();
        }

        @Override
        public void close() throws SQLException {
            this.connection.setAutoCommit(autocommit);
        }

    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy