From 39dacc0b2c9408d3d66cc77ea69a8f96a3dbb027 Mon Sep 17 00:00:00 2001 From: Steve Jones Date: Tue, 16 Apr 2024 14:46:41 +0200 Subject: [PATCH] (#2366) Improve performance of retrieving SensorValues Specifically when ignoring internal calibration values. --- .../QuinCe/data/Dataset/DataSetDataDB.java | 77 +++++++++++++++++-- 1 file changed, 70 insertions(+), 7 deletions(-) diff --git a/WebApp/src/uk/ac/exeter/QuinCe/data/Dataset/DataSetDataDB.java b/WebApp/src/uk/ac/exeter/QuinCe/data/Dataset/DataSetDataDB.java index 32d939bdd..e40b779aa 100644 --- a/WebApp/src/uk/ac/exeter/QuinCe/data/Dataset/DataSetDataDB.java +++ b/WebApp/src/uk/ac/exeter/QuinCe/data/Dataset/DataSetDataDB.java @@ -17,6 +17,7 @@ import java.util.Map; import java.util.Objects; import java.util.TreeMap; +import java.util.TreeSet; import javax.sql.DataSource; @@ -180,6 +181,14 @@ public class DataSetDataDB { + DatabaseUtils.IN_PARAMS_TOKEN + " AND sv.file_column IN " + DatabaseUtils.IN_PARAMS_TOKEN; + private static final String GET_INTERNAL_CALIBRATION_SENSOR_VALUE_IDS_QUERY = "SELECT " + + "sv.id FROM sensor_values sv " + + "INNER JOIN measurements m ON m.date = sv.date " + + "INNER JOIN measurement_run_types mrt ON m.id = mrt.measurement_id " + + "WHERE m.dataset_id = ? AND mrt.run_type IN " + + DatabaseUtils.IN_PARAMS_TOKEN + " AND sv.file_column IN " + + DatabaseUtils.IN_PARAMS_TOKEN + " ORDER BY sv.id"; + private static final String UPDATE_MEASUREMENT_TIME_STATEMENT = "UPDATE measurements " + "SET date = ? WHERE id = ?"; @@ -468,6 +477,13 @@ public static DatasetSensorValues getSensorValues(Connection conn, MissingParam.checkMissing(conn, "conn"); MissingParam.checkZeroPositive(datasetId, "datasetId"); + TreeSet ignoredSensorValues = new TreeSet(); + + if (instrument.hasInternalCalibrations() && ignoreInternalCalibrations) { + ignoredSensorValues = getInternalCalibrationSensorValueIDs(conn, + instrument, datasetId); + } + DatasetSensorValues values = new DatasetSensorValues(instrument); String query = ignoreFlushing @@ -481,18 +497,16 @@ public static DatasetSensorValues getSensorValues(Connection conn, try (ResultSet records = stmt.executeQuery()) { while (records.next()) { - values.add(sensorValueFromResultSet(records, datasetId)); + SensorValue value = sensorValueFromResultSet(records, datasetId); + if (!ignoredSensorValues.contains(value.getId())) { + values.add(value); + } } } } catch (Exception e) { throw new DatabaseException("Error while retrieving sensor values", e); } - if (instrument.hasInternalCalibrations() && ignoreInternalCalibrations) { - values.removeAll( - getInternalCalibrationSensorValues(conn, instrument, datasetId)); - } - return values; } @@ -1181,9 +1195,58 @@ public static void deleteDataReduction(Connection conn, long datasetId) } } + public static TreeSet getInternalCalibrationSensorValueIDs( + Connection conn, Instrument instrument, long datasetId) + throws DatabaseException { + + MissingParam.checkMissing(conn, "conn"); + MissingParam.checkMissing(instrument, "Instrument"); + MissingParam.checkPositive(datasetId, "datasetId"); + + TreeSet result = new TreeSet(); + + List calibrationRunTypes = instrument + .getInternalCalibrationRunTypes(); + List calibratedColumns = instrument.getSensorAssignments() + .getInternalCalibrationSensors(); + + String sql = DatabaseUtils.makeInStatementSql( + GET_INTERNAL_CALIBRATION_SENSOR_VALUE_IDS_QUERY, + calibrationRunTypes.size(), calibratedColumns.size()); + + try (PreparedStatement stmt = conn.prepareStatement(sql)) { + + stmt.setLong(1, datasetId); + + int currentParam = 1; + + for (String runType : calibrationRunTypes) { + currentParam++; + stmt.setString(currentParam, runType); + } + + for (Long column : calibratedColumns) { + currentParam++; + stmt.setLong(currentParam, column); + } + + try (ResultSet records = stmt.executeQuery()) { + while (records.next()) { + result.add(records.getLong(1)); + } + } + + } catch (SQLException e) { + throw new DatabaseException( + "Error while getting calibration sensor values", e); + } + + return result; + } + public static List getInternalCalibrationSensorValues( Connection conn, Instrument instrument, long datasetId) - throws MissingParamException, DatabaseException, InvalidFlagException { + throws DatabaseException, InvalidFlagException { MissingParam.checkMissing(conn, "conn"); MissingParam.checkMissing(instrument, "Instrument");