diff options
author | Simon Brandhof <simon.brandhof@sonarsource.com> | 2017-09-07 22:02:47 +0200 |
---|---|---|
committer | Simon Brandhof <simon.brandhof@sonarsource.com> | 2017-09-07 22:03:15 +0200 |
commit | 4000d244f77a2f99acfc8e8e58571ee13a8a6d77 (patch) | |
tree | c9c313976fd50dcbbcb934ae012c78adc8c16d7f /server/sonar-db-migration | |
parent | db9ce02d06f81e31e108c2e0a4679b3c97c2013b (diff) | |
download | sonarqube-4000d244f77a2f99acfc8e8e58571ee13a8a6d77.tar.gz sonarqube-4000d244f77a2f99acfc8e8e58571ee13a8a6d77.zip |
SONAR-9763 remove double join in DB migration 1267
Diffstat (limited to 'server/sonar-db-migration')
2 files changed, 43 insertions, 12 deletions
diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasures.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasures.java index fd213140d08..c7eca704768 100644 --- a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasures.java +++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasures.java @@ -20,11 +20,13 @@ package org.sonar.server.platform.db.migration.version.v60; import java.sql.SQLException; +import java.util.HashMap; +import java.util.Map; import org.sonar.db.Database; +import org.sonar.server.platform.db.migration.step.DataChange; import org.sonar.server.platform.db.migration.step.MassUpdate; import org.sonar.server.platform.db.migration.step.Select; import org.sonar.server.platform.db.migration.step.SqlStatement; -import org.sonar.server.platform.db.migration.step.DataChange; public class PopulateAnalysisUuidOnMeasures extends DataChange { @@ -34,32 +36,43 @@ public class PopulateAnalysisUuidOnMeasures extends DataChange { @Override public void execute(Context context) throws SQLException { + Map<Long, String> rootSnapshotUuids = loadRootSnapshotUuids(context); + + MassUpdate massUpdate = context.prepareMassUpdate(); // mysql can take hours if the 2 requests are merged into a single one - massUpdate.select("select distinct m.snapshot_id as sId, root_snapshots.uuid as rootUuid " + + massUpdate.select("select distinct m.snapshot_id as sId, s.root_snapshot_id as rootSid " + "from project_measures m " + - "inner join snapshots s on m.snapshot_id=s.id " + - "inner join snapshots root_snapshots on s.root_snapshot_id = root_snapshots.id " + + "inner join snapshots s on m.snapshot_id = s.id " + "where m.analysis_uuid is null " + "union " + - "select distinct m.snapshot_id as sId, root_snapshots.uuid as rootUuid " + + "select distinct m.snapshot_id as sId, s.root_snapshot_id as rootSid " + "from project_measures m " + "inner join snapshots s on m.snapshot_id=s.id " + - "inner join snapshots root_snapshots on s.root_snapshot_id is null and s.id = root_snapshots.id " + "where m.analysis_uuid is null" ); - massUpdate.update("update project_measures set analysis_uuid=? where snapshot_id=? and analysis_uuid is null"); + massUpdate.update("update project_measures set analysis_uuid=? where snapshot_id = ? and analysis_uuid is null"); massUpdate.rowPluralName("measures"); - massUpdate.execute(PopulateAnalysisUuidOnMeasures::handle); + massUpdate.execute((row, update) -> handleRow(row, update, rootSnapshotUuids)); + } + + private static Map<Long, String> loadRootSnapshotUuids(Context context) throws SQLException { + Map<Long, String> snapshotUuidsByIds = new HashMap<>(); + context.prepareSelect("select distinct id, uuid from snapshots where depth=0") + .scroll(row -> snapshotUuidsByIds.put(row.getLong(1), row.getString(2))); + return snapshotUuidsByIds; } - private static boolean handle(Select.Row row, SqlStatement update) throws SQLException { + private static boolean handleRow(Select.Row row, SqlStatement update, Map<Long, String> rootSnapshotUuids) throws SQLException { long snapshotId = row.getLong(1); - String analysisUuid = row.getString(2); + Long rootSnapshotId = row.getNullableLong(2); + String analysisUuid = rootSnapshotUuids.get(rootSnapshotId == null ? snapshotId : rootSnapshotId); + if (analysisUuid == null) { + return false; + } update.setString(1, analysisUuid); update.setLong(2, snapshotId); - return true; } diff --git a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasuresTest.java b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasuresTest.java index 6ce6d93de39..023793635c6 100644 --- a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasuresTest.java +++ b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasuresTest.java @@ -82,6 +82,23 @@ public class PopulateAnalysisUuidOnMeasuresTest { } private String insertSnapshot(long id, String uuid, String qualifier, @Nullable Long rootSnapshotId) { + int depth; + switch (qualifier) { + case "TRK": + depth = 0; + break; + case "BRC": + depth = 1; + break; + case "DIR": + depth = 2; + break; + case "FIL": + depth = 3; + break; + default: + throw new IllegalArgumentException(); + } db.executeInsert( TABLE_SNAPSHOTS, "ID", valueOf(id), @@ -89,7 +106,8 @@ public class PopulateAnalysisUuidOnMeasuresTest { "COMPONENT_UUID", valueOf(id + 10), "ROOT_COMPONENT_UUID", valueOf(id + 10), "ROOT_SNAPSHOT_ID", rootSnapshotId != null ? valueOf(rootSnapshotId) : null, - "QUALIFIER", qualifier); + "QUALIFIER", qualifier, + "DEPTH", valueOf(depth)); return uuid; } |