# HG changeset patch # User Sascha L. Teichmann <sascha.teichmann@intevation.de> # Date 1304890483 0 # Node ID cce054f27dac9152c3700d8631b12e671e4d7721 # Parent 8ab04de0b879b97554c76c346a4d70e0c7fd18b1 Importer: Only accept main value types 'Q', 'W', 'D' and 'T' by default. flys-backend/trunk@1853 c6561f87-3c4e-4783-a992-168aeb5c3f6f diff -r 8ab04de0b879 -r cce054f27dac flys-backend/ChangeLog --- a/flys-backend/ChangeLog Sun May 08 17:55:49 2011 +0000 +++ b/flys-backend/ChangeLog Sun May 08 21:34:43 2011 +0000 @@ -1,3 +1,22 @@ +2011-05-08 Sascha L. Teichmann <sascha.teichmann@intevation.de> + + * src/main/java/de/intevation/flys/importer/StaFileParser.java: + Only accept main value types 'Q', 'W', 'D' and 'T' by default. + '-' is not handled any more because it causes too much constraint + problems. You can overwrite the imported type with the + system property flys.backend.main.value.types" (default "QWTD") + + * src/main/java/de/intevation/flys/importer/ImporterSession.java: + Set session flush mode to manual. Hopefully this improves the + performance a bit. + + * src/main/java/de/intevation/flys/importer/ImportWst.java, + src/main/java/de/intevation/flys/importer/ImportGauge.java, + src/main/java/de/intevation/flys/importer/ImportWstColumn.java, + src/main/java/de/intevation/flys/importer/ImportRange.java, + src/main/java/de/intevation/flys/importer/ImportDischargeTable.java: + Improved logging. + 2011-05-08 Sascha L. Teichmann <sascha.teichmann@intevation.de> * src/main/java/de/intevation/flys/importer/WstColumnValueKey.java: Deleted diff -r 8ab04de0b879 -r cce054f27dac flys-backend/src/main/java/de/intevation/flys/importer/ImportDischargeTable.java --- a/flys-backend/src/main/java/de/intevation/flys/importer/ImportDischargeTable.java Sun May 08 17:55:49 2011 +0000 +++ b/flys-backend/src/main/java/de/intevation/flys/importer/ImportDischargeTable.java Sun May 08 21:34:43 2011 +0000 @@ -10,8 +10,12 @@ import de.intevation.flys.model.Gauge; import de.intevation.flys.model.TimeInterval; +import org.apache.log4j.Logger; + public class ImportDischargeTable { + private static Logger log = Logger.getLogger(ImportDischargeTable.class); + protected DischargeTable peer; protected String description; @@ -96,6 +100,7 @@ public void storeDependencies(Gauge gauge) { + log.info("store discharge table '" + description + "'"); storeDischargeTableValues(gauge); } diff -r 8ab04de0b879 -r cce054f27dac flys-backend/src/main/java/de/intevation/flys/importer/ImportGauge.java --- a/flys-backend/src/main/java/de/intevation/flys/importer/ImportGauge.java Sun May 08 17:55:49 2011 +0000 +++ b/flys-backend/src/main/java/de/intevation/flys/importer/ImportGauge.java Sun May 08 21:34:43 2011 +0000 @@ -197,14 +197,17 @@ Gauge gauge = getPeer(river); + log.info("store main value types"); for (ImportMainValueType mainValueType: mainValueTypes) { mainValueType.getPeer(); } + log.info("store named main values"); for (ImportNamedMainValue namedMainValue: namedMainValues) { namedMainValue.getPeer(); } + log.info("store main values"); for (ImportMainValue mainValue: mainValues) { mainValue.getPeer(river); } @@ -214,11 +217,13 @@ } public void storeDischargeTable(Gauge gauge) { + log.info("store discharge table"); dischargeTable.getPeer(gauge); dischargeTable.storeDependencies(gauge); } public void storeHistoricalDischargeTable(Gauge gauge) { + log.info("store historical discharge tables"); for (ImportDischargeTable hdt: historicalDischargeTables) { hdt.storeDependencies(gauge); } diff -r 8ab04de0b879 -r cce054f27dac flys-backend/src/main/java/de/intevation/flys/importer/ImportRange.java --- a/flys-backend/src/main/java/de/intevation/flys/importer/ImportRange.java Sun May 08 17:55:49 2011 +0000 +++ b/flys-backend/src/main/java/de/intevation/flys/importer/ImportRange.java Sun May 08 21:34:43 2011 +0000 @@ -73,7 +73,7 @@ query.setParameter("a", a); query.setParameter("b", b); query.setParameter("river", river); - log.debug("a: " + a + " b: " + b + " river.id: " + river.getId()); + //log.debug("a: " + a + " b: " + b + " river.id: " + river.getId()); List<Range> ranges = query.list(); if (ranges.isEmpty()) { peer = new Range(a, b, river); diff -r 8ab04de0b879 -r cce054f27dac flys-backend/src/main/java/de/intevation/flys/importer/ImportWst.java --- a/flys-backend/src/main/java/de/intevation/flys/importer/ImportWst.java Sun May 08 17:55:49 2011 +0000 +++ b/flys-backend/src/main/java/de/intevation/flys/importer/ImportWst.java Sun May 08 21:34:43 2011 +0000 @@ -13,7 +13,7 @@ public class ImportWst { - private static Logger logger = Logger.getLogger(ImportWst.class); + private static Logger log = Logger.getLogger(ImportWst.class); protected String description; @@ -65,6 +65,8 @@ } public void storeDependencies(River river) { + + log.info("store '" + description + "'"); Wst wst = getPeer(river); for (ImportWstColumn column: columns) { diff -r 8ab04de0b879 -r cce054f27dac flys-backend/src/main/java/de/intevation/flys/importer/ImportWstColumn.java --- a/flys-backend/src/main/java/de/intevation/flys/importer/ImportWstColumn.java Sun May 08 17:55:49 2011 +0000 +++ b/flys-backend/src/main/java/de/intevation/flys/importer/ImportWstColumn.java Sun May 08 21:34:43 2011 +0000 @@ -12,8 +12,12 @@ import java.math.BigDecimal; +import org.apache.log4j.Logger; + public class ImportWstColumn { + private static Logger log = Logger.getLogger(ImportWstColumn.class); + protected ImportWst wst; protected String name; protected String description; @@ -85,10 +89,14 @@ } public void storeDependencies(River river) { + log.info("store column '" + description + "'"); WstColumn column = getPeer(river); + log.info("store q ranges"); for (ImportWstColumnQRange columnQRange: columnQRanges) { columnQRange.getPeer(river); } + + log.info("store w values"); for (ImportWstColumnValue columnValue: columnValues) { columnValue.getPeer(river); } diff -r 8ab04de0b879 -r cce054f27dac flys-backend/src/main/java/de/intevation/flys/importer/ImporterSession.java --- a/flys-backend/src/main/java/de/intevation/flys/importer/ImporterSession.java Sun May 08 17:55:49 2011 +0000 +++ b/flys-backend/src/main/java/de/intevation/flys/importer/ImporterSession.java Sun May 08 21:34:43 2011 +0000 @@ -9,6 +9,7 @@ import org.hibernate.SessionFactory; import org.hibernate.Session; import org.hibernate.Query; +import org.hibernate.FlushMode; import de.intevation.flys.backend.SessionFactoryProvider; @@ -41,6 +42,7 @@ SessionFactory sessionFactory = SessionFactoryProvider.createSessionFactory(); databaseSession = sessionFactory.openSession(); + databaseSession.setFlushMode(FlushMode.MANUAL); } public Session getDatabaseSession() { diff -r 8ab04de0b879 -r cce054f27dac flys-backend/src/main/java/de/intevation/flys/importer/StaFileParser.java --- a/flys-backend/src/main/java/de/intevation/flys/importer/StaFileParser.java Sun May 08 17:55:49 2011 +0000 +++ b/flys-backend/src/main/java/de/intevation/flys/importer/StaFileParser.java Sun May 08 21:34:43 2011 +0000 @@ -22,8 +22,12 @@ public static final String ENCODING = "ISO-8859-1"; + public static final String TYPES = + System.getProperty("flys.backend.main.value.types", "QWTD"); + public static final Pattern QWTD_ = - Pattern.compile("\\s*([^\\s]+)\\s+([^\\s]+)\\s+([QWTD-]).*"); + Pattern.compile("\\s*([^\\s]+)\\s+([^\\s]+)\\s+([" + + Pattern.quote(TYPES) + "]).*"); public StaFileParser() { }