关于网友提出的“ hibernate批量查询优化”问题疑问,本网通过在网上对“ hibernate批量查询优化”有关的相关答案进行了整理,供用户进行参考,详细问题解答如下:
问题: hibernate批量查询优化
描述: getHibernateTemplate().find()这个方法优化有啥好方法
解决方案1: 楼主是想进行哪方面的优化?批量查询更新导入数据的话,不推荐使用Hibernate
以为它们会使用缓存
解决方案2: 怎么个优化法?你是想继续对find()方法封装还是对数据库的查询进行优化?
如果对查询进行优化的话建议使用第三方缓存(如果数据频繁修改就不要用了)
解决方案3: 见 夏新 《深入浅出 Hibernate》使用 session.iterator(hql,*******),等价于 session.createQuery().iterator()方法。
find 其实是无法利用 hibernate 最重要的缓存机制的。find方法查询出来的记录对缓存只写不读。而 sesssion.iterator方法可以充分利用缓存。
问题:session.itreator第一次是一个 N+1次的查询。开始会较慢。内存占用会较大,可以配合 evict方法使用,避免内存溢出。
不过,真正对效能要求高的话,最好的办法还是 jdbc和存储过程。
以上介绍了“ hibernate批量查询优化”的问题解答,希望对有需要的网友有所帮助。
本文网址链接:http://www.codes51.com/itwd/3207957.html