我有下面的代码片段,我正在使用休眠查询。它工作正常。当我触发第二次执行此代码时,不会触发查询,因为它是从查询缓存中选取的
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。但是在休眠文档中它没有写在任何地方。所以只是想知道我在这里错过了什么