Mercurial > dive4elements > river
view flys-backend/src/main/java/de/intevation/flys/model/HydrBoundaryPoly.java @ 5745:ed9d7e360658
Merged.
author | Felix Wolfsteller <felix.wolfsteller@intevation.de> |
---|---|
date | Wed, 17 Apr 2013 15:00:38 +0200 |
parents | 87dab419b924 |
children |
line wrap: on
line source
package de.intevation.flys.model; import java.io.Serializable; import java.util.List; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToOne; import javax.persistence.Table; import javax.persistence.SequenceGenerator; import org.hibernate.Session; import org.hibernate.Query; import org.hibernate.annotations.Type; import com.vividsolutions.jts.geom.Geometry; import de.intevation.flys.backend.SessionHolder; @Entity @Table(name = "hydr_boundaries_poly") public class HydrBoundaryPoly implements Serializable { private Integer id; private String name; private River river; private Geometry geom; private SectieKind sectie; private SobekKind sobek; private BoundaryKind kind; public HydrBoundaryPoly() { } @Id @SequenceGenerator( name = "SEQUENCE_HYDR_BOUNDARIES_POLY_ID_SEQ", sequenceName = "HYDR_BOUNDARIES_POLY_ID_SEQ", allocationSize = 1) @GeneratedValue( strategy = GenerationType.SEQUENCE, generator = "SEQUENCE_HYDR_BOUNDARIES_POLY_ID_SEQ") @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 Geometry getGeom() { return geom; } public void setGeom(Geometry geom) { this.geom = geom; } public static List<HydrBoundaryPoly> getHydrBoundaries(int riverId, String name) { Session session = SessionHolder.HOLDER.get(); Query query = session.createQuery( "from HydrBoundaryPoly where river.id =:river_id and name=:name"); query.setParameter("river_id", riverId); query.setParameter("name", name); return query.list(); } public static List<HydrBoundaryPoly> getHydrBoundaries(int riverId, int kind, int sectie, int sobek) { Session session = SessionHolder.HOLDER.get(); String filter = " where river.id =:river_id"; if (kind != -1) { filter += " and kind = " + kind; } if (sectie != -1) { filter += " and sectie = " + sectie; } if (sobek != -1){ filter += " and sobek = " + sobek; } Query query = session.createQuery("from HydrBoundaryPoly" + filter); query.setParameter("river_id", riverId); return query.list(); } /** * Get sectie. * * @return sectie as SectieKind. */ @OneToOne @JoinColumn(name = "sectie") public SectieKind getSectie() { return sectie; } /** * Set sectie. * * @param sectie the value to set. */ public void setSectie(SectieKind sectie) { this.sectie = sectie; } /** * Get sobek. * * @return sobek as SobekKind. */ @OneToOne @JoinColumn(name = "sobek") public SobekKind getSobek() { return sobek; } /** * Set sobek. * * @param sobek the value to set. */ public void setSobek(SobekKind sobek) { this.sobek = sobek; } /** * Get kind. * * @return kind as BoundaryKind. */ @OneToOne @JoinColumn(name = "kind") public BoundaryKind getKind() { return kind; } /** * Set kind. * * @param kind the value to set. */ public void setKind(BoundaryKind kind) { this.kind = kind; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :