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

52 篇文章 0 订阅

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

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值