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.QueryConnectFieldTerm_;
import fi.otavanopisto.muikku.plugins.CorePluginsDAO;
import fi.otavanopisto.muikku.plugins.material.model.QueryConnectField;
import fi.otavanopisto.muikku.plugins.material.model.QueryConnectFieldCounterpart;
import fi.otavanopisto.muikku.plugins.material.model.QueryConnectFieldTerm;
public class QueryConnectFieldTermDAO extends CorePluginsDAO<QueryConnectFieldTerm> {
private static final long serialVersionUID = -5327160259588566934L;
public QueryConnectFieldTerm create(QueryConnectField field, String name, String text, QueryConnectFieldCounterpart counterpart) {
QueryConnectFieldTerm queryConnectFieldTerm = new QueryConnectFieldTerm();
queryConnectFieldTerm.setName(name);
queryConnectFieldTerm.setText(text);
queryConnectFieldTerm.setField(field);
queryConnectFieldTerm.setCounterpart(counterpart);
return persist(queryConnectFieldTerm);
}
public QueryConnectFieldTerm findByFieldAndName(QueryConnectField field, String name) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<QueryConnectFieldTerm> criteria = criteriaBuilder.createQuery(QueryConnectFieldTerm.class);
Root<QueryConnectFieldTerm> root = criteria.from(QueryConnectFieldTerm.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(QueryConnectFieldTerm_.field), field),
criteriaBuilder.equal(root.get(QueryConnectFieldTerm_.name), name)
)
);
return getSingleResult(entityManager.createQuery(criteria));
}
public List<QueryConnectFieldTerm> listByField(QueryConnectField field) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<QueryConnectFieldTerm> criteria = criteriaBuilder.createQuery(QueryConnectFieldTerm.class);
Root<QueryConnectFieldTerm> root = criteria.from(QueryConnectFieldTerm.class);
criteria.select(root);
criteria.where(criteriaBuilder.equal(root.get(QueryConnectFieldTerm_.field), field));
return entityManager.createQuery(criteria).getResultList();
}
public QueryConnectFieldTerm updateText(QueryConnectFieldTerm queryConnectFieldTerm, String text) {
queryConnectFieldTerm.setText(text);
return persist(queryConnectFieldTerm);
}
public QueryConnectFieldTerm updateCounterpart(QueryConnectFieldTerm queryConnectFieldTerm, QueryConnectFieldCounterpart counterpart) {
queryConnectFieldTerm.setCounterpart(counterpart);
return persist(queryConnectFieldTerm);
}
public void delete(QueryConnectFieldTerm queryConnectFieldTerm) {
super.delete(queryConnectFieldTerm);
}
}