You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

DdlChange.java 2.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /*
  2. * SonarQube, open source software quality management tool.
  3. * Copyright (C) 2008-2014 SonarSource
  4. * mailto:contact AT sonarsource DOT com
  5. *
  6. * SonarQube is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * SonarQube is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. package org.sonar.server.db.migrations;
  21. import java.sql.Connection;
  22. import java.sql.SQLException;
  23. import org.apache.commons.dbutils.DbUtils;
  24. import org.sonar.db.Database;
  25. public abstract class DdlChange implements MigrationStep {
  26. private final Database db;
  27. public DdlChange(Database db) {
  28. this.db = db;
  29. }
  30. @Override
  31. public final void execute() throws SQLException {
  32. Connection writeConnection = null;
  33. try {
  34. writeConnection = db.getDataSource().getConnection();
  35. writeConnection.setAutoCommit(false);
  36. Context context = new Context(writeConnection);
  37. execute(context);
  38. } finally {
  39. DbUtils.closeQuietly(writeConnection);
  40. }
  41. }
  42. public static class Context {
  43. private final Connection writeConnection;
  44. public Context(Connection writeConnection) {
  45. this.writeConnection = writeConnection;
  46. }
  47. public void execute(String sql) throws SQLException {
  48. try {
  49. UpsertImpl.create(writeConnection, sql).execute().commit();
  50. } catch (Exception e) {
  51. throw new IllegalStateException(String.format("Fail to execute %s", sql), e);
  52. }
  53. }
  54. }
  55. public abstract void execute(Context context) throws SQLException;
  56. }