MyBatis的一級緩存和二級緩存
阿新 • • 發佈:2019-03-11
config lec 實體 set -- acache 序列 batis ssi
一級緩存
是SqlSession級別的緩存,當使用了clearCache方法和,或者close方法的話,這個緩存失效,如果還有同樣的查詢,則還會發送一次查詢
SqlSession session = SqlSessionFactoryUtil.getSession(); Emp emp = session.selectOne("queryEmpByNo", 7900); System.out.println(emp); Emp emp2 = session.selectOne("queryEmpByNo", 7900); System.out.println(emp2);
二級緩存
二級緩存是跨sqlsession的緩存,就是mapper緩存,也就是說,如果前面執行了close方法,後一個SqlSession查詢,是可以在SqlSession查詢到的,但如果執行了cleaCache方法,則不行
步驟
需要在mybatis的核心配置文件(mybatis-config.xml)
<!-- 開啟全局二級緩存 --> <setting name="cacheEnabled" value="true"/>
在mapper.xml文件裏也要開啟緩存
<!--開啟緩存--> <cache/>
實體類要支持序列化,也就是實現Serializable接口
SqlSession session = SqlSessionFactoryUtil.getSession(); Emp emp = session.selectOne("queryEmpByNo", 7900); System.out.println(emp); session.close(); session = SqlSessionFactoryUtil.getSession(); Emp emp2 = session.selectOne("queryEmpByNo", 7900); System.out.println(emp2);
MyBatis的一級緩存和二級緩存