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 :