ingo@2808: package de.intevation.flys.importer; ingo@2808: ingo@2809: import java.util.List; ingo@2809: ingo@2808: import org.apache.log4j.Logger; ingo@2808: ingo@2809: import org.hibernate.Session; ingo@2809: import org.hibernate.Query; ingo@2809: ingo@2809: import de.intevation.flys.model.BedHeightType; ingo@2809: ingo@2808: ingo@2808: public class ImportBedHeightType { ingo@2808: ingo@2808: private static final Logger log = ingo@2808: Logger.getLogger(ImportBedHeightType.class); ingo@2808: ingo@2808: protected String name; ingo@2808: protected String description; ingo@2808: ingo@2809: protected BedHeightType peer; ingo@2809: ingo@2808: ingo@2808: public ImportBedHeightType(String name, String description) { ingo@2808: this.name = name; ingo@2808: this.description = description; ingo@2808: } ingo@2808: ingo@2808: ingo@2809: public void storeDependencies() { ingo@2809: BedHeightType type = getPeer(); ingo@2809: } ingo@2809: ingo@2809: ingo@2809: public BedHeightType getPeer() { ingo@2809: if (peer == null) { ingo@2809: Session session = ImporterSession.getInstance().getDatabaseSession(); ingo@2809: ingo@2809: Query query = session.createQuery( ingo@2809: "from BedHeightType where " + ingo@2809: "name=:name and description=:description"); ingo@2809: ingo@2809: query.setParameter("name", name); ingo@2809: query.setParameter("description", description); ingo@2809: ingo@2809: List types = query.list(); ingo@2809: ingo@2809: if (types.isEmpty()) { ingo@2809: peer = new BedHeightType(name, description); ingo@2809: session.save(peer); ingo@2809: } ingo@2809: else { ingo@2809: peer = types.get(0); ingo@2809: } ingo@2808: } ingo@2809: ingo@2809: return peer; ingo@2808: } ingo@2808: } ingo@2808: // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :