JPA性能调优会需要特别注意的2点

时间:2021-08-28 19:53:25

JPA非常好用,可以很好的简化系统开发,只不过有时候也会带来很大的伤害,特别在性能方面。
一用JPA,大家都知道要注意lazy load 和 eager load,其实还有2点也很重要:
1. 哪些数据列需要读取
2. N+1 issue (http://*.com/questions/97197/what-is-the-n1-selects-issue)

第一个问题的解决在于jpql/hql在select的时候要制定自己需要哪些属性,例如select p.id from Product p where p.status:=?

第二个问题的解决需要使用join fetch(https://docs.jboss.org/hibernate/orm/3.3/reference/en/html/queryhql.html#queryhql-joins),通过inner/left/outer join,可以一次SQL取出所有要用的对象,而不会出现n+1 select问题,在对象复杂的时候,对性能的提示是巨大的。

from Cat as cat
inner join fetch cat.mate
left join fetch cat.kittens child
left join fetch child.kittens

在我们的系统中,通过join fetch,在20个对象的查询处理上,时间由6s变成了300ms。