java - Hibernate查询缓存适用于 native 查询吗?

标签 java hibernate

我有下面的代码片段,我正在使用 hibernate 查询。效果很好。当我第二次执行此代码时 时间查询不会被触发,因为它是从查询缓存中选取的

   Session session = hibernateFactory.openSession();
    Query employeeQuery=session.createQuery("from Employee where employeeId=1");//line 1
    employeeQuery.setCacheable(true);
    Employee employee1=(Employee)employeeQuery.uniqueResult();
    session.close();

但是当我用下面的行替换上面代码片段中的 line1 时,我就会得到异常

Query employeeQuery=session.createSQLQuery("select * from Employee where employeeId=1");

异常(exception)是

    Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0
at org.hibernate.type.TypeHelper.disassemble(TypeHelper.java:146)
at org.hibernate.cache.StandardQueryCache.put(StandardQueryCache.java:106)
at org.hibernate.loader.Loader.putResultInQueryCache(Loader.java:2434)
at org.hibernate.loader.Loader.listUsingQueryCache(Loader.java:2321)
at org.hibernate.loader.Loader.list(Loader.java:2268)

查询缓存不适用于 native 查询吗?

更新:- 我认为查询缓存适用于 HQL,不适用于 native SQL。但在 hibernate 文档中它没有写在任何地方。所以只是想知道我在这里错过了什么

最佳答案

SQLQuery 不支持缓存。它可以帮助你。

http://www.tutorialspoint.com/hibernate/hibernate_caching.htm

最好使用 hibernate SQL sintaxis。

关于java - Hibernate查询缓存适用于 native 查询吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15595627/

相关文章:

java - JPA,保存关系而不查询实体

java - 如何从oracle中的hibernate元数据获取列注释?

hibernate - 将 ORM 与严格的 MVC 框架结合使用

java - 集成 Pentaho/Talend/等使用 OR 映射器

eclipse - 类未找到 : org. springframework.web.servlet.DispatcherServlet

java - 保留字的 SQL 语法错误 (Java)

java - 我的 History() 方法面临问题,如何根据最旧的更改进行排序?

java - Selenium IE 驱动程序找不到新打开的窗口

java - 尝试在空对象引用上调用虚拟方法 '...(java.util.ArrayList)'

java - Android 构建错误 com.google.firebase :firebase-core:16. 0.8