1.Hibernate通过sessionFactory获取session的方法
1)openSession()获取一个新的session。
2)getCurrentSession()获取当前线程绑定的session。
区别:openSession()获取一个新的session,而getCurrentSession()获取当前线程绑定的session。getCurrentSession()获取的session在事物提交后会自动关闭。openSession()获取的则需要手动关闭。
2.get()和load()的区别
1)get在执行的时候先到一级和二级缓存区查找,如果没有则直接执行sql语句到数据库查找,如果查不到这个数据则返回null。
2)load也是先到一二级缓存区查找,如果没有则返回一个代理对象,等后面用到这个对象的时候才会去DB查找,这就是load默认情况下支持延迟加载。如果不存在这个数据则会抛出异常。
3.解决n+1问题
首先明确一下n+1问题,当两张如学生信息表Student_info和成绩汇总表SummaryGrade的关系是多对一的时候,如果对Student_info表进行查询操作,则hibernate也会向多的那张表对应SummaryGrade执行查找操作。
解决办法:
1)设置@ManyToOne的fetch属性为fetchType.LAZY,但这样的话如果需要级联查询就无法获取级联对象了。
2)设置@BatchSize(size=5),这个注释放在和@Entity相同的位置,这样发出的多余的查询语句就会减少,但这不是最优雅的。
3)在hqp语句中使用用jion fecth。这是最好方法。