问题描述
- JPA查询效率过于缓慢的问题
-
一个最简单的JPA查询语句。hibernate4.0支持的JPA版本。在数据库执行原生SQL只要5ms在JPA entityManager里用query执行JPQL却需要400MS左右。我也是醉了。没法玩了JPA。求大神给答案
解决方案
Hibernate 处理 ManyToOne OneToOne的时候,default是Eager Fetch,导致取下来是整颗对象树,本以为是限制取的层数,实际发现不是,这个只是限制用JOIN连接表的层数,如果超过这么多层,下面的会另外生成SQL语句去取,直到完整一棵对象树取完,大量的SQL语句导致效率及其低下,域模型越复杂效率越低!
解决方式:ManyToOne OneToOne 都用lazy fetch,当需要使用lazy对象的时候,left join fetch 之。
时间: 2024-09-15 14:37:53