ingo@301: package de.intevation.flys.artifacts.model; ingo@301: ingo@301: import java.util.List; ingo@301: ingo@301: import de.intevation.flys.backend.SessionFactoryProvider; ingo@301: ingo@301: import de.intevation.flys.model.Annotation; ingo@301: import de.intevation.flys.model.Range; ingo@301: import de.intevation.flys.model.River; ingo@301: ingo@301: import org.hibernate.SessionFactory; ingo@301: import org.hibernate.Session; ingo@301: import org.hibernate.Query; ingo@301: ingo@301: ingo@301: /** ingo@301: * @author Ingo Weinzierl ingo@301: */ ingo@301: public class AnnotationsFactory { ingo@301: ingo@301: public static List getAnnotations(River river) { ingo@301: return getAnnotations(river.getName()); ingo@301: } ingo@301: ingo@301: ingo@301: public static List getAnnotations(String river) { ingo@301: SessionFactory sf = SessionFactoryProvider.getSessionFactory(); ingo@301: Session session = sf.openSession(); ingo@301: ingo@301: try { ingo@301: Query rangesQuery = session.createQuery( ingo@301: "from Range where river.name=:name"); ingo@301: rangesQuery.setParameter("name", river); ingo@301: List ranges = rangesQuery.list(); ingo@301: ingo@301: Query query = session.createQuery( ingo@301: "from Annotation where range in (:ranges)"); ingo@301: query.setParameterList("ranges", ranges); ingo@301: return query.list(); ingo@301: } ingo@301: finally { ingo@301: session.close(); ingo@301: } ingo@301: } ingo@301: } ingo@301: // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :