Mercurial > dive4elements > river
diff flys-backend/src/main/java/de/intevation/flys/importer/ImportDepth.java @ 2817:8979f2294af9
Finished parsing MINFO specific sediment density.
flys-backend/trunk@4234 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Fri, 13 Apr 2012 11:45:29 +0000 |
parents | f121c0f456ab |
children | 7c1dd9c3f6bd |
line wrap: on
line diff
--- a/flys-backend/src/main/java/de/intevation/flys/importer/ImportDepth.java Fri Apr 13 10:59:15 2012 +0000 +++ b/flys-backend/src/main/java/de/intevation/flys/importer/ImportDepth.java Fri Apr 13 11:45:29 2012 +0000 @@ -2,8 +2,13 @@ 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.Depth; @@ -29,13 +34,42 @@ public void storeDependencies() { log.info("store dependencies"); + + getPeer(); } public Depth getPeer() { log.info("get peer"); - return null; + if (peer == null) { + Session session = ImporterSession.getInstance().getDatabaseSession(); + + Query query = session.createQuery( + "from Depth where " + + " lower=:lower and " + + " upper=:upper and " + + " unit=:unit"); + + query.setParameter("lower", lower); + query.setParameter("upper", upper); + query.setParameter("unit", unit.getPeer()); + + List<Depth> depths = query.list(); + + if (depths.isEmpty()) { + log.debug("Create new Depth DB instance."); + + peer = new Depth(lower, upper, unit.getPeer()); + + session.save(peer); + } + else { + peer = depths.get(0); + } + } + + return peer; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :