org.sonar.db.version.MassUpdate Maven / Gradle / Ivy
/*
* SonarQube
* Copyright (C) 2009-2016 SonarSource SA
* mailto:contact AT sonarsource DOT com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
package org.sonar.db.version;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.concurrent.atomic.AtomicLong;
import org.sonar.core.util.ProgressLogger;
import org.sonar.db.Database;
public class MassUpdate {
public interface Handler {
/**
* Convert some column values of a given row.
*
* @return true if the row must be updated, else false. If false, then the update parameter must not be touched.
*/
boolean handle(Select.Row row, SqlStatement update) throws SQLException;
}
private final Database db;
private final Connection readConnection;
private final Connection writeConnection;
private final AtomicLong counter = new AtomicLong(0L);
private final ProgressLogger progress = ProgressLogger.create(getClass(), counter);
private Select select;
private Upsert update;
MassUpdate(Database db, Connection readConnection, Connection writeConnection) {
this.db = db;
this.readConnection = readConnection;
this.writeConnection = writeConnection;
}
public SqlStatement select(String sql) throws SQLException {
this.select = SelectImpl.create(db, readConnection, sql);
return this.select;
}
public MassUpdate update(String sql) throws SQLException {
this.update = UpsertImpl.create(writeConnection, sql);
return this;
}
public MassUpdate rowPluralName(String s) {
this.progress.setPluralLabel(s);
return this;
}
public void execute(final Handler handler) throws SQLException {
if (select == null || update == null) {
throw new IllegalStateException("SELECT or UPDATE requests are not defined");
}
progress.start();
try {
select.scroll(new Select.RowHandler() {
@Override
public void handle(Select.Row row) throws SQLException {
if (handler.handle(row, update)) {
update.addBatch();
}
counter.getAndIncrement();
}
});
if (((UpsertImpl) update).getBatchCount() > 0L) {
update.execute().commit();
}
update.close();
// log the total number of processed rows
progress.log();
} finally {
progress.stop();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy