在 Hibernate 5.2 中,SharedSessionContract.createCriteria(Class persistentClass) 的正确替代方法

2022-09-01 19:33:12

我正在从Hibernate 3.x升级到最新的Hibernate 5.2.0 FINAL。在我的旧代码中,我们使用标准查询,如下所示。

Session session =getHibernateTemplate().getSessionFactory().getCurrentSession();
Criteria criteria = session.createCriteria(Employee.class);
criteria.add(Restrictions.eq("Department", department));
return criteria.list();

现在,从Hibernate 5.2.0开始,createCriteria()方法已被弃用。可以从以下文档中找到。

https://docs.jboss.org/hibernate/orm/5.2/javadocs/deprecated-list.html https://docs.jboss.org/hibernate/orm/5.2/javadocs/org/hibernate/SharedSessionContract.html#createCriteria-java.lang.Class-

文档建议使用 JPA 标准。以下是我基于上述背景的几个问题。

  1. 由于我们没有使用EntityManager并且严重依赖于HibernateDAOSupport和HibernateTemplate,我如何通过会话或会话工厂使用JAP标准?

  2. 如果我使用分离标准,如下面的代码片段所示,它是否与以前的实现相同,或者下面的代码会给我们提供与会话无关的结果?

    DetachedCriteria criteria = DetachedCriteria.forClass(Employee.class);
    criteria.add(Restrictions.eq("Department", department));
    return (List<Employee>) getHibernateTemplate().findByCriteria(criteria);
    
  3. 同样作为替代方案,如果我以下面提到的方式使用分离标准,它是否会产生与我的旧代码相同的影响。

    Session session  =getHibernateTemplate().getSessionFactory().getCurrentSession();
    DetachedCriteria criteria = DetachedCriteria.forClass(Employee.class);
    criteria.add(Restrictions.eq("Department", department));
    return criteria .getExecutableCriteria(session).list();
    

如果有更好的方法来解决这个问题,请建议,因为我不想改变HibernateDAOSupport和HibernateTemplate的使用。


答案 1

使用 CriteriaBuilder,如下所述:

//Use below imports:
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;

//creating session. This you can create in your own way.
Configuration cfg = new Configuration();
cfg.configure("hibernate.cfg.xml");
cfg.addAnnotatedClass(Employee.class);

SessionFactory factory = cfg.buildSessionFactory();
Session session = factory.openSession();

//**creating CriteriaBuilder**
CriteriaBuilder builder = session.getCriteriaBuilder();
CriteriaQuery<Employee> criteria = builder.createQuery(Employee.class);
Root<Employee> employeeRoot=criteria.from(Employee.class);
criteria.select(employeeRoot);

//**Adding where clause**
criteria.where(builder.equal(employeeRoot.get("employeeId"), "E01"));
List<Employee> employeeList=session.createQuery(criteria).getResultList();

答案 2

文档链接后面是状态:

“legacy Hibernate org.hibernate.Criteria API,应被视为已弃用”

因此,只需切换到分离标准就可以摆脱当前的折旧,但它建议使用JPA标准(不支持org.hibernate.criteria.Restrictions等)。目前尚不清楚,路线图也没有多大帮助。

它确实提到:

“最终,特定于Hibernate的标准功能将作为扩展移植到JPA javax.persistence.criteria.CriteriaQuery”

你有没有更进一步?


推荐