当前位置:  开发笔记 > 编程语言 > 正文

Hibernate 5 - 不推荐使用createCriteria

如何解决《Hibernate5-不推荐使用createCriteria》经验,为你挑选了1个好方法。

我需要帮助来使用createCriteriafor 迁移代码Hibernate 5,代码如下:

public Curso comDadosIguais(Curso curso) {
    return (Curso) this.session.createCriteria(Curso.class)
            .add(Restrictions.eq("codigo", curso.getCodigo()))
            .uniqueResult();
}

你可以帮帮我吗?



1> Naros..:

您可以使用许多选项从已弃用的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();
CriteriaQuery query = 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();

推荐阅读
云聪京初瑞子_617
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有