我需要帮助来使用createCriteria
for 迁移代码Hibernate 5
,代码如下:
public Curso comDadosIguais(Curso curso) { return (Curso) this.session.createCriteria(Curso.class) .add(Restrictions.eq("codigo", curso.getCodigo())) .uniqueResult(); }
你可以帮帮我吗?
您可以使用许多选项从已弃用的Hibernate Criteria API进行迁移,这些只是一些可以立即想到的:
HQL/JPQL
命名查询
JPA Criteria API
从HQL/JPQL的角度来看,您可以将查询重写为字符串:
Curso result = session.createQuery( "FROM Curso WHERE codigo = :codigo" ) .setParameter( "codigo", curso.getCodigo() ) .uniqueResult();
你也可以使用一个@NamedQuery
基本上是你应用于实体的包或你提供HQL查询的包的注释,就像你上面看到的那样,以相同的方式指定查询参数的占位符,然后提供这些参数是运行时你执行查询,如:
Curso result = session.createNamedQuery( "Curso.findByCodigo" ) .setParameter( "codigo", curso.getCodigo() ) .uniqueResult();
最后,您还可以考虑JPA Criteria API.如果您使用的是JPA EntityManager
而不是Hibernate,则可以使用此功能Session
.
CriteriaBuilder cb = entityManager.getCriteriaBuilder(); CriteriaQueryquery = cb.createQuery( Curso.class ); Root root = query.from( Curso.class ); query.select( root ) .where( cb.eq( root.get( "codigo" ), curso.getCodigo() ) ); Curso result = entityManager.createQuery( query ).getSingleResult();