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,就不会再去数据库里取了。
相关推荐
solarspot 2020-07-28
83520298 2020-07-06
houmenghu 2020-11-17
我心似明月 2020-11-09
oraclemch 2020-11-06
ltd00 2020-09-12
康慧欣 2020-09-10
waveclouds 2020-09-04
蓝色深海 2020-09-15
jincheng 2020-09-01
思君夜未眠 2020-08-25
取个好名字真难 2020-08-06
歆萌 2020-08-03
阳光之吻 2020-08-03
婷婷小屋 2020-07-28
MLXY 2020-07-26
dxbjfu0 2020-07-26
songbinxu 2020-07-19