【发布时间】:2016-01-19 02:43:14
【问题描述】:
查询、本机查询、命名查询和类型查询之间有什么区别? “独立”查询是否存在,或者它只是一个缩写?在我看来,原生查询是用简单的 sql 编写的查询,而命名查询与实体相关(休眠映射)。有人能简单解释一下吗?
【问题讨论】:
标签: sql hibernate jpa native-sql
查询、本机查询、命名查询和类型查询之间有什么区别? “独立”查询是否存在,或者它只是一个缩写?在我看来,原生查询是用简单的 sql 编写的查询,而命名查询与实体相关(休眠映射)。有人能简单解释一下吗?
【问题讨论】:
标签: sql hibernate jpa native-sql
查询
查询是指JPQL/HQL查询,其语法类似于通常用于执行DML语句(CRUD操作)的SQL。
在 JPA 中,您可以使用 entityManager.createQuery() 创建查询。您可以查看API 了解更多详情。
在 Hibernate 中,您使用 session.createQuery()"
NativeQuery
本机查询是指实际的 sql 查询(指实际的数据库对象)。这些查询是可以使用数据库客户端直接在数据库中执行的sql语句。
JPA : entityManager.createNativeQuery()
Hibernate(非 JPA 实现):session.createSQLQuery()
命名查询
类似于常量的定义。 NamedQuery 是您通过为查询命名来定义查询的方式。您可以在休眠的映射文件中定义它,也可以在实体级别使用注释。
TypedQuery
TypedQuery 为您提供了在创建查询时提及实体类型的选项,因此此后的任何操作都不需要显式转换为预期类型。而普通的 Query API 不会返回您期望的确切类型的 Object 并且您需要强制转换。
【讨论】: