0
我使用帶有泛型實現的Abstract Base類來使用JPA訪問我的數據庫。 我也使用實體元模型。如何以通用方式檢查Meta模型類的字段?
public List<PersonEntity> findByCode(String code) {
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
CriteriaQuery<PersonEntity> cq = cb.createQuery(PersonEntity.class);
Root<PersonEntity> root = cq.from(PersonEntity.class);
Predicate predicate = cb.equal(root.get(PersonEntity_.code), code);
cq.where(predicate);
TypedQuery<PersonEntity> query = entityManager.createQuery(cq);
List<PersonEntity> list = new ArrayList<>();
return query.getResultList();
}
我想把它移到一個通用的基類中,因爲這代碼的和平使用了很多次。 如何檢查是否有「代碼」?並不是所有的課程都有。
public List<E> findByCode(String code) {
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
CriteriaQuery<E> cq = cb.createQuery(entityClass);
Root<E> root = cq.from(entityClass);
//here is my problem: how to check if there is a "code"?
// Most classes have one, but not all.
Predicate predicate = cb.equal(root.get(PersonEntity_.code), code);
cq.where(predicate);
TypedQuery<E> query = entityManager.createQuery(cq);
List<E> list = new ArrayList<>();
return query.getResultList();
}