1.一级缓存是SqlSession级别的缓存。在操作数库时需要构造SqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(hashMap)是互不影响的。
2.二级缓存是mapper级别的缓存,多个sqlSerssion去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的,二级缓存底层还是个HashMap实现的。
总结:
1.一级缓存是每个SqlSession私有的缓存区域(SqlSession级别的缓存),默认开启。
例如:一个Session做了一个查询操作,它会把这个操作的结果放在一级缓存中。如果短时间内这个session(必须是同一个session)又做了同一个操作,那么直接从一级缓存中拿,而不会再去连接数据库,取数据。
2.二级缓存是多个SqlSession共有的缓存区域,默认关闭,放在二级缓存中的对象必须实现序列化接口。
工作原理:在当次会话中的相同查询会储存进一级缓存,当sqlSession的会话关闭了(前提要开启二级缓存),该sqlsession的一级缓存数据就回储存到二级缓存中。
二级缓存的开启要求:
1.xml配置中开启二级缓存
2.去mapper映射文件中使用二级缓存
3.需要将要存储数据对象实现序列化,为了将数据去除做反序列化的操作,因为二级缓存的存储方式多种多样,有可能存储在内存中,有可能存储在硬盘中。