Hibernate查询缓存适用于本机查询?

时间:2013-03-24 05:50:52

标签: 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 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)

查询缓存不适用于本机查询吗?

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

1 个答案:

答案 0 :(得分:1)

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

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

最好使用hibernate SQL sintaxis。