一个最简单的JPA查询语句。hibernate4.0支持的JPA版本。在数据库执行原生SQL只要5ms在JPA entityManager里用query执行JPQL却需要400MS左右。我也是醉了。没法玩了JPA。求大神给答案
1条回答
- fnkfdn 2016-05-12 12:24关注
Hibernate 处理 ManyToOne OneToOne的时候,default是Eager Fetch,导致取下来是整颗对象树,本以为是限制取的层数,实际发现不是,这个只是限制用JOIN连接表的层数,如果超过这么多层,下面的会另外生成SQL语句去取,直到完整一棵对象树取完,大量的SQL语句导致效率及其低下,域模型越复杂效率越低!
解决方式:ManyToOne OneToOne 都用lazy fetch,当需要使用lazy对象的时候,left join fetch 之。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报