Mercurial > dive4elements > river
view flys-backend/src/main/java/de/intevation/flys/importer/ImportFlowVelocityMeasurement.java @ 5707:53134ccc4a64
Backend: Import Flow Velocity Model: Use unique km for station.
author | Sascha L. Teichmann <teichmann@intevation.de> |
---|---|
date | Mon, 15 Apr 2013 15:45:18 +0200 |
parents | 3bd786772798 |
children |
line wrap: on
line source
package de.intevation.flys.importer; import java.util.ArrayList; import java.util.List; import org.apache.log4j.Logger; import org.hibernate.Session; import org.hibernate.Query; import de.intevation.flys.model.FlowVelocityMeasurement; import de.intevation.flys.model.River; public class ImportFlowVelocityMeasurement { private static final Logger log = Logger .getLogger(ImportFlowVelocityMeasurement.class); private String description; private List<ImportFlowVelocityMeasurementValue> values; private FlowVelocityMeasurement peer; public ImportFlowVelocityMeasurement() { this(null); } public ImportFlowVelocityMeasurement(String description) { this.description = description; this.values = new ArrayList<ImportFlowVelocityMeasurementValue>(); } public void setDescription(String description) { this.description = description; } public void addValue(ImportFlowVelocityMeasurementValue value) { this.values.add(value); } public void storeDependencies(River river) { log.debug("store dependencies"); FlowVelocityMeasurement peer = getPeer(river); if (peer != null) { for (ImportFlowVelocityMeasurementValue value : values) { value.storeDependencies(peer); } } } public FlowVelocityMeasurement getPeer(River river) { if (peer == null) { Session session = ImporterSession.getInstance() .getDatabaseSession(); Query query = session .createQuery("from FlowVelocityMeasurement where " + " river=:river and " + " description=:description"); query.setParameter("river", river); query.setParameter("description", description); List<FlowVelocityMeasurement> measurement = query.list(); if (measurement.isEmpty()) { peer = new FlowVelocityMeasurement(river, description); session.save(peer); } else { peer = measurement.get(0); } } return peer; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :