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,就不会再去数据库里取了。