HIbernate_性能调优

1.大数据量重复填充session时,应该在每次调用之后调用session.clear();

 

2.1+N问题(由Fetch=Eager造成,会发出N个sql调用)的解决方法:

  1).将Fetch设为Lazy

  2).调用session.createCriteria(class),因为这个默认会做左连接。不会发出N的SQL调用。

  3).使用@BatchSize(size=xxx)(注意需要放到N的类头上),可以让1+N问题变为1+N/2,1+N/3,1+N/4.......,这取决于你设定size的大小。

  4).在HQL中写left join fetch(right join fetch).比如session.createQuery("from xxx  t from left join fetch xxx c")。这样就会只有一条使用了left join 的sql文。

 

3.List Iterator的区别

  1).List把所有都取出来,iterator会先取主健,等到用到其他属性的时候,再根据取出来的主健取属性的值。一般情况下用list,因为iteratore会使用session级的缓存,在特别情况下才使用。

  2).正是由于iterator会使用session级的缓存,所以当在一个session内部重复使用结果的时候,iterator不会再去取了,list就不会,实际情况中,如果确实想用的话,可以第一次用list往内存放,再使用的时候用iterator,就不会再去数据库里取了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值