我是基于Java EE的项目的链接标准查询,但我不确定它是否是一个好习惯。
它有许多优点,例如它可以减少代码,更重要的是可以重用初始查询。但我不知道它的缺点是什么。
请看一次,并建议我是否走在正确的轨道上。它在我的项目中表现非常出色。
public abstract class AbstractFacade<T> {
private Class<T> entityClass;
protected CriteriaQuery<T> criteriaQuery;
protected CriteriaBuilder criteriaBuilder;
protected Root<T> from;
protected List<Predicate> predicates;
@PostConstruct
protected void _startQuery() {
this.criteriaBuilder = getEntityManager().getCriteriaBuilder();
this.criteriaQuery = this.criteriaBuilder.createQuery(entityClass);
from = this.criteriaQuery.from(entityClass);
predicates = new ArrayList<Predicate>();
}
.......................... ..........................
}
public abstract class AbstractUserLoggableFacade<T extends AbstractUserLoggable> extends AbstractFacade<T> {
.................
}
public abstract class OrganizationTrackableFacade<T extends OrganizationalTrackable> extends AbstractUserLoggableFacade<T> {
........................
}
最后是实现类。
@Stateless
public class DayStartFacade extends OrganizationTrackableFacade<DayStart> {
@TransactionAttribute(TransactionAttributeType.NEVER)
private DayStartFacade filterByEnded(Boolean b) {
this.predicates.add(criteriaBuilder.equal(from.get(DayStart_.isEnded), b));
return this;
}
@TransactionAttribute(TransactionAttributeType.NEVER)
private DayStartFacade filterByOrganization(Organization o) {
this.predicates.add(criteriaBuilder.equal(from.get(OrganizationalTrackable_.organizationId), o));
return this;
}
这是我的链式方法。用这种方式链接是一种好习惯吗?
public DayStart getCurrentDayStart() {
DayStart d = null;
try {
d = ((DayStartFacade) this.startQuery()).filterByEnded(Boolean.FALSE).filterByOrganization(userBean.getCurrentOrganization()).getSingleResult();
} catch (javax.persistence.NonUniqueResultException e) {
System.out.println("No unique restult exception at getCurrentDayStart");
e.printStackTrace();
} catch (javax.persistence.NoResultException nre) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
return d;
}
}
我正在使用JPA 2.0,Hibernate和GlassFish。
答案 0 :(得分:1)
如果不行,API将不允许它。由于javax.persistence.criteria
包中充满了这种模式,因此可能会这样做。