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.QuerySelectFieldOption_;
import fi.otavanopisto.muikku.plugins.CorePluginsDAO;
import fi.otavanopisto.muikku.plugins.material.model.QuerySelectField;
import fi.otavanopisto.muikku.plugins.material.model.QuerySelectFieldOption;
public class QuerySelectFieldOptionDAO extends CorePluginsDAO<QuerySelectFieldOption> {
private static final long serialVersionUID = -5327160259588566934L;
public QuerySelectFieldOption create(String name, String text, QuerySelectField field) {
QuerySelectFieldOption querySelectFieldOption = new QuerySelectFieldOption();
querySelectFieldOption.setName(name);
querySelectFieldOption.setText(text);
querySelectFieldOption.setSelectField(field);
return persist(querySelectFieldOption);
}
public List<QuerySelectFieldOption> listByField(QuerySelectField field) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<QuerySelectFieldOption> criteria = criteriaBuilder.createQuery(QuerySelectFieldOption.class);
Root<QuerySelectFieldOption> root = criteria.from(QuerySelectFieldOption.class);
criteria.select(root);
criteria.where(criteriaBuilder.equal(root.get(QuerySelectFieldOption_.selectField), field));
return entityManager.createQuery(criteria).getResultList();
}
public QuerySelectFieldOption findBySelectFieldAndName(QuerySelectField selectField, String name) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<QuerySelectFieldOption> criteria = criteriaBuilder.createQuery(QuerySelectFieldOption.class);
Root<QuerySelectFieldOption> root = criteria.from(QuerySelectFieldOption.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(QuerySelectFieldOption_.selectField), selectField),
criteriaBuilder.equal(root.get(QuerySelectFieldOption_.name), name)
)
);
return getSingleResult(entityManager.createQuery(criteria));
}
public List<QuerySelectFieldOption> listBySelectField(QuerySelectField selectField) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<QuerySelectFieldOption> criteria = criteriaBuilder.createQuery(QuerySelectFieldOption.class);
Root<QuerySelectFieldOption> root = criteria.from(QuerySelectFieldOption.class);
criteria.select(root);
criteria.where(
criteriaBuilder.equal(root.get(QuerySelectFieldOption_.selectField), selectField)
);
return entityManager.createQuery(criteria).getResultList();
}
public QuerySelectFieldOption updateText(QuerySelectFieldOption querySelectFieldOption, String text) {
querySelectFieldOption.setText(text);
return persist(querySelectFieldOption);
}
public void delete(QuerySelectFieldOption querySelectFieldOption) {
super.delete(querySelectFieldOption);
}
}