view flys-backend/src/main/java/de/intevation/flys/model/GaugeLocation.java @ 4174:eaf83d4ae6b1

Sorted gauges for reference gauge selection in historical discharge calculation based on their name. Now, Gauge implements the Java Comparable interface and takes its name into account.
author Ingo Weinzierl <ingo.weinzierl@intevation.de>
date Thu, 18 Oct 2012 13:12:24 +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