mschaefer@8971: /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde mschaefer@8971: * Software engineering by mschaefer@8971: * Björnsen Beratende Ingenieure GmbH mschaefer@8971: * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt mschaefer@8971: * mschaefer@8971: * This file is Free Software under the GNU AGPL (>=v3) mschaefer@8971: * and comes with ABSOLUTELY NO WARRANTY! Check out the mschaefer@8971: * documentation coming with Dive4Elements River for details. mschaefer@8971: */ mschaefer@8971: mschaefer@8971: package org.dive4elements.river.importer.sinfo.importitem; mschaefer@8971: mschaefer@8971: import java.util.List; mschaefer@8971: mschaefer@8971: import org.apache.log4j.Logger; mschaefer@8971: import org.dive4elements.river.importer.common.AbstractSeriesImport; mschaefer@8971: import org.dive4elements.river.model.River; mschaefer@8971: import org.dive4elements.river.model.sinfo.Channel; mschaefer@8971: import org.dive4elements.river.model.sinfo.ChannelValue; mschaefer@8971: import org.hibernate.Query; mschaefer@8971: import org.hibernate.Session; mschaefer@8971: mschaefer@8971: /** mschaefer@8971: * Imported channel data series of a river mschaefer@8971: * mschaefer@8971: * @author Matthias Schäfer mschaefer@8971: * mschaefer@8971: */ mschaefer@8971: public class ChannelSeriesImport extends AbstractSeriesImport { mschaefer@8971: mschaefer@8971: /***** FIELDS *****/ mschaefer@8971: mschaefer@8971: private static Logger log = Logger.getLogger(ChannelSeriesImport.class); mschaefer@8971: mschaefer@8971: private Integer year_from; mschaefer@8971: mschaefer@8971: private Integer year_to; mschaefer@8971: mschaefer@8971: mschaefer@8971: /***** CONSTRUCTORS *****/ mschaefer@8971: mschaefer@8971: public ChannelSeriesImport(final String filename) { mschaefer@8971: super(filename); mschaefer@8971: } mschaefer@8971: mschaefer@8971: mschaefer@8971: /***** METHODS *****/ mschaefer@8971: mschaefer@8971: public void setYear_from(final Integer year_from) { mschaefer@8971: this.year_from = year_from; mschaefer@8971: } mschaefer@8971: mschaefer@8971: public void setYear_to(final Integer year_to) { mschaefer@8971: this.year_to = year_to; mschaefer@8971: } mschaefer@8971: mschaefer@8971: @Override mschaefer@8971: public Logger getLog() { mschaefer@8971: return log; mschaefer@8971: } mschaefer@8971: mschaefer@8971: @Override mschaefer@9653: public List querySeriesItem(final Session session, final River river, final boolean doQueryParent) { mschaefer@9653: final Query query = session.createQuery("FROM Channel WHERE river=:river AND (lower(filename)=:filename" mschaefer@9653: + " OR (:newfrom BETWEEN year_from AND year_to) OR (:newto BETWEEN year_from AND year_to))"); mschaefer@8971: query.setParameter("river", river); mschaefer@9653: query.setParameter("filename", this.filename.toLowerCase()); mschaefer@9653: query.setParameter("newfrom", this.year_from); mschaefer@9653: query.setParameter("newto", this.year_to); mschaefer@8971: return query.list(); mschaefer@8971: } mschaefer@8971: mschaefer@8971: @Override mschaefer@8971: public Channel createSeriesItem(final River river) { mschaefer@9038: return new Channel(river, this.filename, this.kmrange_info, this.notes, this.year_from, this.year_to); mschaefer@8971: } mschaefer@8971: }