java – HQL查询总是命中数据库并获得结果吗?

前端之家收集整理的这篇文章主要介绍了java – HQL查询总是命中数据库并获得结果吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在经历hibernate以及何时使用Criteria vs HQL的情况,我的理解是使用Hibernate,每当我们在两个实例中通过Criteria或HQL查询数据库时,hibernate将得到结果集并放入内存然后当我们调用它时再次查询,数据将从内存中获取而不是点击该数据库,我的理解是否正确?

另外正如您在下面提到的评论和问题中所看到的那样,有人建议Hibernate Criteria会从会话中获取数据,而HQL总会进入并命中数据库,因此对HQL查询的任何数量的多次调用都会进入并命中数据库,如果这是然后HQL引起的问题多于解决问题.

请对此提出建议,因为我对这种情况有点困惑.

参考question

解决方法

这取决于您正在进行的查询类型以及缓存设置.

Hibernate有三种缓存:会话缓存,查询缓存和二级缓存.会话缓存始终打开,但其他两个可以禁用.

通常,缓存不是支持Criteria API而不是HQL的原因,反之亦然.对于基本相同的东西,它们大多只是不同的接口.

http://www.javalobby.org/java/forums/t48846.htmlhttp://docs.jboss.org/hibernate/core/3.3/reference/en/html/performance.html

猜你在找的Java相关文章