[英]Hibernate 5 - createCriteria deprecated
我需要帮助来使用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的角度来看,您可以将查询重写为字符串:
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();
CriteriaQuery<Curso> query = cb.createQuery( Curso.class );
Root<Curso> root = query.from( Curso.class );
query.select( root )
.where( cb.eq( root.get( "codigo" ), curso.getCodigo() ) );
Curso result = entityManager.createQuery( query ).getSingleResult();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.