hibernate主要从以下几个方面来优化查询性能
1,降低访问数据库的频率,减少select语句的数目,实现手段有:使用迫切左外连接或迫切内连接;对延迟检索或立即检索设置批量检索数目;使用查询缓存。
2,避免加载多余的应用程序不需要访问的数据,实现手段有:使用延迟加载策略;使用集合过滤。
3,避免报表查询数据占用缓存,实现手段为利用投影查询功能,查询出实体的部分属性。
4,减少select语句中的字段,从而降低访问数据库的数据量,实现手段为利用Query的iterate()方法。Query的iterate()方法首先检索ID字段,然后根据ID字段到hibernate的第一级缓存以及第二级缓存中查找匹配的 Customer对象,如果存在,就直接把它加入到查询结果集中,否则就执行额外的select语句,根据ID字段到数据库中检索该对象。