teichmann@5844: /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde teichmann@5844: * Software engineering by Intevation GmbH teichmann@5844: * teichmann@5992: * This file is Free Software under the GNU AGPL (>=v3) teichmann@5844: * and comes with ABSOLUTELY NO WARRANTY! Check out the teichmann@5992: * documentation coming with Dive4Elements River for details. teichmann@5844: */ teichmann@5844: teichmann@5829: package org.dive4elements.river.model; ingo@1230: ingo@1230: import java.io.Serializable; ingo@2366: import java.util.List; ingo@1230: ingo@1230: import javax.persistence.Column; ingo@1230: import javax.persistence.Entity; ingo@1230: import javax.persistence.Id; ingo@1230: import javax.persistence.JoinColumn; ingo@1230: import javax.persistence.OneToOne; ingo@1230: import javax.persistence.Table; ingo@1230: ingo@2366: import org.hibernate.Session; ingo@2366: import org.hibernate.Query; ingo@1230: import org.hibernate.annotations.Type; ingo@1230: ingo@1230: import com.vividsolutions.jts.geom.LineString; ingo@1230: teichmann@5829: import org.dive4elements.river.backend.SessionHolder; ingo@2366: ingo@1230: ingo@1230: @Entity ingo@1230: @Table(name = "buildings") ingo@1230: public class Building ingo@1230: implements Serializable ingo@1230: { ingo@1230: private Integer id; ingo@1230: private River river; ingo@1230: private String name; ingo@1230: private LineString geom; ingo@1230: ingo@1230: public Building() { ingo@1230: } ingo@1230: ingo@1230: ingo@1230: @Id ingo@1230: @Column(name = "id") ingo@1230: public Integer getId() { ingo@1230: return id; ingo@1230: } ingo@1230: ingo@1230: ingo@1230: public void setId(Integer id) { ingo@1230: this.id = id; ingo@1230: } ingo@1230: ingo@1230: ingo@1230: @OneToOne ingo@1230: @JoinColumn(name = "river_id") ingo@1230: public River getRiver() { ingo@1230: return river; ingo@1230: } ingo@1230: ingo@1230: ingo@1230: public void setRiver(River river) { ingo@1230: this.river = river; ingo@1230: } ingo@1230: ingo@1230: ingo@1230: @Column(name = "name") ingo@1230: public String getName() { ingo@1230: return name; ingo@1230: } ingo@1230: ingo@1230: ingo@1230: public void setName(String name) { ingo@1230: this.name = name; ingo@1230: } ingo@1230: ingo@1230: ingo@1230: @Column(name = "geom") ingo@1230: @Type(type = "org.hibernatespatial.GeometryUserType") ingo@1230: public LineString getGeom() { ingo@1230: return geom; ingo@1230: } ingo@1230: ingo@1230: ingo@1230: public void setGeom(LineString geom) { ingo@1230: this.geom = geom; ingo@1230: } ingo@2366: aheinecke@5402: public static List getBuildings(int riverId, int kindId) { aheinecke@5402: Session session = SessionHolder.HOLDER.get(); aheinecke@5402: aheinecke@5402: Query query = session.createQuery( aheinecke@5402: "from Building where river.id =:river_id and kind_id=:kind_id"); aheinecke@5402: query.setParameter("kind_id", kindId); aheinecke@5402: query.setParameter("river_id", riverId); aheinecke@5402: aheinecke@5402: return query.list(); aheinecke@5402: } ingo@2366: ingo@2868: public static List getBuildings(int riverId, String name) { ingo@2366: Session session = SessionHolder.HOLDER.get(); ingo@2366: ingo@2366: Query query = session.createQuery( ingo@2868: "from Building where river.id =:river_id and name=:name"); ingo@2366: query.setParameter("river_id", riverId); ingo@2868: query.setParameter("name", name); ingo@2366: ingo@2366: return query.list(); ingo@2366: } ingo@1230: } ingo@1230: // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :