view flys-backend/src/main/java/de/intevation/flys/model/GaugeLocation.java @ 4173:7d4480c0e68e

Allow users to select the current relevant discharge table in historical discharge table calculattion. In addition to this, the discharge tables in the helper panel displayed in the client is ordered in time.
author Ingo Weinzierl <ingo.weinzierl@intevation.de>
date Thu, 18 Oct 2012 12:13:48 +0200
parents 8f905390c10d
children
line wrap: on
line source
package de.intevation.flys.model;

import com.vividsolutions.jts.geom.Point;

import de.intevation.flys.backend.SessionHolder;

import java.io.Serializable;

import java.util.List;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.OneToOne;
import javax.persistence.Table;

import org.hibernate.Query;
import org.hibernate.Session;

import org.hibernate.annotations.Type;


@Entity
@Table(name = "gauge_location")
public class GaugeLocation
implements   Serializable
{
    private Integer    id;
    private River      river;
    private String     name;
    private Point      geom;


    public GaugeLocation() {
    }


    @Id
    @Column(name = "id")
    public Integer getId() {
        return id;
    }


    public void setId(Integer id) {
        this.id = id;
    }


    @OneToOne
    @JoinColumn(name = "river_id")
    public River getRiver() {
        return river;
    }


    public void setRiver(River river) {
        this.river = river;
    }


    @Column(name = "name")
    public String getName() {
        return name;
    }


    public void setName(String name) {
        this.name = name;
    }


    @Column(name = "geom")
    @Type(type = "org.hibernatespatial.GeometryUserType")
    public Point getGeom() {
        return geom;
    }


    public void setGeom(Point geom) {
        this.geom = geom;
    }


    /**
     * Returns a list of RiverAxisKm objects for a given river.
     *
     * @param riverid The ID of a river in the database.
     *
     * @return a list of RiverAxisKm objects.
     */
    public static List<GaugeLocation> getGaugeLocations(int riverid, String name) {
        Session session = SessionHolder.HOLDER.get();

        Query query = session.createQuery(
            "from GaugeLocation where river.id =:riverid and name=:name");
        query.setParameter("riverid", riverid);
        query.setParameter("name", name);

        List<GaugeLocation> list = query.list();

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

http://dive4elements.wald.intevation.org