view flys-backend/src/main/java/de/intevation/flys/importer/ImportFlowVelocityMeasurementValue.java @ 2832:ac5bd90697c1

Added new parser for flow velocity measurements and fixed some smaller bugs while importing flow velocity data. flys-backend/trunk@4250 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Ingo Weinzierl <ingo.weinzierl@intevation.de>
date Tue, 17 Apr 2012 13:00:04 +0000
parents 8fe9c6584b93
children 4ee97d914501
line wrap: on
line source
package de.intevation.flys.importer;

import java.math.BigDecimal;
import java.sql.SQLException;
import java.util.Date;
import java.util.List;

import org.apache.log4j.Logger;

import org.hibernate.Session;
import org.hibernate.Query;
import org.hibernate.exception.ConstraintViolationException;

import de.intevation.flys.model.FlowVelocityMeasurement;
import de.intevation.flys.model.FlowVelocityMeasurementValue;


public class ImportFlowVelocityMeasurementValue {

    private static final Logger log =
        Logger.getLogger(ImportFlowVelocityMeasurementValue.class);


    private Date datetime;

    private String description;

    private BigDecimal station;
    private BigDecimal w;
    private BigDecimal q;
    private BigDecimal v;

    private FlowVelocityMeasurementValue peer;


    public ImportFlowVelocityMeasurementValue(
        Date       datetime,
        BigDecimal station,
        BigDecimal w,
        BigDecimal q,
        BigDecimal v,
        String     description
    ) {
        this.datetime    = datetime;
        this.station     = station;
        this.w           = w;
        this.q           = q;
        this.v           = v;
        this.description = description;
    }



    public void storeDependencies(FlowVelocityMeasurement measurement)
    throws SQLException, ConstraintViolationException
    {
        log.debug("store dependencies");

        getPeer(measurement);
    }


    public FlowVelocityMeasurementValue getPeer(FlowVelocityMeasurement m) {
        if (peer == null) {
            Session session = ImporterSession.getInstance().getDatabaseSession();

            Query query = session.createQuery(
                "from FlowVelocityMeasurementValue where " +
                "   measurement=:measurement and " +
                "   station=:station and " +
                "   datetime=:datetime"
            );

            query.setParameter("measurement", m);
            query.setParameter("station", station);
            query.setParameter("datetime", datetime);

            List<FlowVelocityMeasurementValue> values = query.list();

            if (values.isEmpty()) {
                peer = new FlowVelocityMeasurementValue(
                    m,
                    datetime,
                    station,
                    w,
                    q,
                    v,
                    description);

                session.save(peer);
            }
            else {
                peer = values.get(0);
            }
        }

        return peer;
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org