aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-db-migration
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@sonarsource.com>2017-09-07 22:02:47 +0200
committerSimon Brandhof <simon.brandhof@sonarsource.com>2017-09-07 22:03:15 +0200
commit4000d244f77a2f99acfc8e8e58571ee13a8a6d77 (patch)
treec9c313976fd50dcbbcb934ae012c78adc8c16d7f /server/sonar-db-migration
parentdb9ce02d06f81e31e108c2e0a4679b3c97c2013b (diff)
downloadsonarqube-4000d244f77a2f99acfc8e8e58571ee13a8a6d77.tar.gz
sonarqube-4000d244f77a2f99acfc8e8e58571ee13a8a6d77.zip
SONAR-9763 remove double join in DB migration 1267
Diffstat (limited to 'server/sonar-db-migration')
-rw-r--r--server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasures.java35
-rw-r--r--server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v60/PopulateAnalysisUuidOnMeasuresTest.java20
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;
}