Mercurial > dive4elements > river
view flys-backend/src/main/java/de/intevation/flys/importer/ImportSedimentDensityValue.java @ 4746:0b60b77d4d00
DA66Parser: Handle coding convention that was introduced to overcome fixed
length fields.
author | Felix Wolfsteller <felix.wolfsteller@intevation.de> |
---|---|
date | Thu, 03 Jan 2013 09:57:22 +0100 |
parents | be9e28cff0c4 |
children | db6c7268b08e |
line wrap: on
line source
package de.intevation.flys.importer; import java.math.BigDecimal; import java.util.List; import org.apache.log4j.Logger; import org.hibernate.Session; import org.hibernate.Query; import de.intevation.flys.model.SedimentDensity; import de.intevation.flys.model.SedimentDensityValue; public class ImportSedimentDensityValue { private static final Logger log = Logger.getLogger(ImportSedimentDensityValue.class); protected SedimentDensityValue peer; protected BigDecimal station; protected BigDecimal density; private BigDecimal year; protected String description; public ImportSedimentDensityValue( BigDecimal station, BigDecimal density, BigDecimal year, String description ) { this.station = station; this.density = density; this.year = year; this.description = description; } public void storeDependencies(SedimentDensity sedimentDensity) { log.info("store dependencies"); getPeer(sedimentDensity); } public SedimentDensityValue getPeer(SedimentDensity sedimentDensity) { log.info("get peer"); if (peer == null) { Session session = ImporterSession.getInstance().getDatabaseSession(); Query query = session.createQuery( "from SedimentDensityValue where " + " sedimentDensity=:sedimentDensity and " + " station=:station and " + " density=:density and " + " year=:year and " + " description=:description"); query.setParameter("sedimentDensity", sedimentDensity); query.setParameter("station", station); query.setParameter("density", density); query.setParameter("year", year); query.setParameter("description", description); List<SedimentDensityValue> values = query.list(); if (values.isEmpty()) { log.debug("Create new SedimentDensityValue DB instance."); peer = new SedimentDensityValue( sedimentDensity, station, density, year, description); session.save(peer); } else { peer = values.get(0); } } return peer; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :