package fi.otavanopisto.muikku.plugins.material.dao; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import javax.persistence.criteria.Root; import fi.otavanopisto.muikku.plugins.material.model.QueryField_; import fi.otavanopisto.muikku.plugins.CorePluginsDAO; import fi.otavanopisto.muikku.plugins.material.model.Material; import fi.otavanopisto.muikku.plugins.material.model.QueryField; public class QueryFieldDAO extends CorePluginsDAO<QueryField> { private static final long serialVersionUID = -5327160259588566934L; public QueryField findByMaterialAndName(Material material, String name) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<QueryField> criteria = criteriaBuilder.createQuery(QueryField.class); Root<QueryField> root = criteria.from(QueryField.class); criteria.select(root); criteria.where( criteriaBuilder.and( criteriaBuilder.equal(root.get(QueryField_.material), material), criteriaBuilder.equal(root.get(QueryField_.name), name) ) ); return getSingleResult(entityManager.createQuery(criteria)); } public List<QueryField> listByMaterial(Material material) { EntityManager entityManager = getEntityManager(); CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder(); CriteriaQuery<QueryField> criteria = criteriaBuilder.createQuery(QueryField.class); Root<QueryField> root = criteria.from(QueryField.class); criteria.select(root); criteria.where( criteriaBuilder.equal(root.get(QueryField_.material), material) ); return entityManager.createQuery(criteria).getResultList(); } public void delete(QueryField queryField) { super.delete(queryField); } }