Hibernate 缓存机制:
担心:两张表查询(关联查询)起来效率会不会低呢??hibernate 缓存机制非常强大。。。
缓存:介于应用程序和物理数据源之间为了降低应用程序对物理数据源的访问频率,从而提高应用的运行性能(缓存内的数据是对物理数据源的复制,缓存的介质一般是内存,所以读取速度很快;如果缓存中的年数据量很大 将硬盘作为介质)。缓存的实现不仅考虑介质,换应该考虑缓存的并发访问和缓存数据的生命周期。
Hibernate是一个持久层框架,经常访问物理数据库,为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能。
N+1问题:
N+1问题:
返回查询列表时获取对象的两种方法:
list() 方法会发出sql 查询出该对象;(一条sql)
iterator()方法 会发出取 id 列表的sql ,在查询相应的具体的某个学生信息时,会发出相应的SQL去取学生信息;
iterator()方法 来获得对象时,hibernate会先发出取出所有对象id 值 的sql ,大会需要查询某个对象 的具体信息时,hibernate会根据取出的 id 值 发出相应的SQL 语句从数据库中去取具体的对象信息,这就是典型的N+1 问题!
iterator()方法 获取对象是产生N+1问题 为什么不直接用list() 还要保留iterator()方法 ??
list() 方法每次返回对象,而iterator()方法先返回对象id ,需要查询具体对象信息才会发出相应的sql 语句去查询 ,既节省了内存花费;例如:再一个session中要两次查询多个对象时,如果两条都用list() ,一定会发出两条sql 而且两条语句一样,但是如果你第一条使用list() 方法(查出了所有对象),第二条使用iterator() 方法(查询出对象 id) ,也是两条sql 但是明显第二条只是根据id 对应第一条查出来的对象而已,可以节省内存;而如果再要获取对象的时候,因为第一条语句已经将对象都查询出来了,此时会将对象保存到session的一级缓存中去,所以再次查询时,就