changeset 4103:2305731f563c

Store W/Q in sets to prevent value duplications. flys-aft/trunk@3633 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Sascha L. Teichmann <sascha.teichmann@intevation.de>
date Mon, 09 Jan 2012 17:09:25 +0000 (2012-01-09)
parents e8967ee1cb05
children cdcf98245e36
files flys-aft/ChangeLog flys-aft/src/main/java/de/intevation/aft/DischargeTable.java
diffstat 2 files changed, 26 insertions(+), 17 deletions(-) [+]
line wrap: on
line diff
--- a/flys-aft/ChangeLog	Mon Jan 09 16:43:14 2012 +0000
+++ b/flys-aft/ChangeLog	Mon Jan 09 17:09:25 2012 +0000
@@ -1,3 +1,13 @@
+2012-01-09	Sascha L. Teichmann	<sascha.teichmann@inteavtion.de>
+
+	* src/main/java/de/intevation/aft/DischargeTable.java: Store 
+	  the W/Q values in sets to prevent value duplications leading
+	  to unique constraint violations in FLYS. Log a warning
+	  when loading a W/Q value duplication.
+
+	  This have the nice side effect that the W/Q values are
+	  written sorted by Q/W which is of benefit for FLYS.
+
 2012-01-09	Sascha L. Teichmann	<sascha.teichmann@inteavtion.de>
 
 	* src/main/java/de/intevation/aft/River.java: Fixed logic bug
--- a/flys-aft/src/main/java/de/intevation/aft/DischargeTable.java	Mon Jan 09 16:43:14 2012 +0000
+++ b/flys-aft/src/main/java/de/intevation/aft/DischargeTable.java	Mon Jan 09 17:09:25 2012 +0000
@@ -3,6 +3,8 @@
 import java.util.List;
 import java.util.Date;
 import java.util.ArrayList;
+import java.util.TreeSet;
+import java.util.Set;
 
 import java.sql.SQLException;
 import java.sql.ResultSet;
@@ -21,7 +23,7 @@
     protected int          gaugeId;
     protected TimeInterval timeInterval;
     protected String       description;
-    protected List<WQ>     values;
+    protected Set<WQ>      values;
 
     public DischargeTable() {
     }
@@ -34,7 +36,7 @@
         this.gaugeId      = gaugeId;
         this.timeInterval = timeInterval;
         this.description  = description;
-        values = new ArrayList<WQ>();
+        values = new TreeSet<WQ>(WQ.EPS_CMP);
     }
 
     public DischargeTable(
@@ -83,16 +85,15 @@
         values.clear();
     }
 
-    public List<WQ> getValues() {
+    public Set<WQ> getValues() {
         return values;
     }
 
-    public void setValues(List<WQ> values) {
+    public void setValues(Set<WQ> values) {
         this.values = values;
     }
 
 
-
     protected void loadValues(SymbolicStatement.Instance query) 
     throws SQLException
     {
@@ -101,7 +102,9 @@
             int    id = rs.getInt("id");
             double w  = rs.getDouble("w");
             double q  = rs.getDouble("q");
-            values.add(new WQ(id, w, q));
+            if (!values.add(new WQ(id, w, q))) {
+                log.warn("Value duplication w="+w+" q="+q+". -> ignore.");
+            }
         }
         rs.close();
     }
@@ -132,23 +135,19 @@
         SymbolicStatement.Instance nextId = flysStatements
             .getStatement("next.discharge.table.values.id");
 
-        int [] ids = new int[values.size()];
-        for (int i = 0; i < ids.length; ++i) {
-            ResultSet rs = nextId.executeQuery();
-            rs.next();
-            ids[i] = rs.getInt("discharge_table_values_id");
-            rs.close();
-        }
-
         // Insert the values.
         SymbolicStatement.Instance insertDTV = flysStatements
             .getStatement("insert.discharge.table.value");
 
-        for (int i = 0; i < ids.length; ++i) {
-            WQ wq = values.get(i);
+        for (WQ wq: values) {
+            ResultSet rs = nextId.executeQuery();
+            rs.next();
+            int wqId = rs.getInt("discharge_table_values_id");
+            rs.close();
+
             insertDTV
                 .clearParameters()
-                .setInt("id", ids[i])
+                .setInt("id", wqId)
                 .setInt("table_id", dischargeTableId)
                 .setDouble("w", wq.getW())
                 .setDouble("q", wq.getQ())

http://dive4elements.wald.intevation.org