首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在hibernate-5中运行命名查询时,如何确保它使用的是JPA2.1标准

在hibernate-5中运行命名查询时,如何确保它使用的是JPA2.1标准
EN

Stack Overflow用户
提问于 2019-05-17 12:05:51
回答 1查看 58关注 0票数 0

在hibernate-5中运行命名查询时,如何确保它使用JPA2.1标准(JPQL语法)

当在hibernate5中运行时,它执行得很好,在JPA2.1中,这应该会失败,我需要在什么/哪里设置一些东西来使用JPA标准(JPQL语法)。

代码语言:javascript
复制
String queryString = "from DeptEmployee where employeeNumber = :employeeNo";
Query jpaQuery = entityManager.createQuery(queryString);

在针对Hibernate-5中的JPQL语法运行时,这应该会抛出异常(因为没有"select“关键字),但是在不设置JPQL语法的情况下应该运行得很好。

我想使用Hibernate5引擎运行,但仍然想保留JPA实现。顺便说一句,我尝试了这个属性'hibernate.query.jpaql_strict_compliance= true',这不起作用。参考:http://docs.jboss.org/hibernate/orm/5.2/javadocs/org/hibernate/cfg/AvailableSettings.html#JPAQL_STRICT_COMPLIANCE

EN

回答 1

Stack Overflow用户

发布于 2019-05-17 18:56:54

因为Hibernate是底层的JPA实现,它接受HQL风格的查询(没有select)。

顺便说一句。你为什么想做那件事?

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56179461

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档