MyBatis的一級緩存和二級緩存


一級緩存

是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方法,則不行

步驟
  1. 需要在mybatis的核心配置文件(mybatis-config.xml)
    <!-- 開啟全局二級緩存 -->
    <setting name="cacheEnabled" value="true"/>
    
  2. 在mapper.xml文件里也要開啟緩存
    <!--開啟緩存-->
    <cache/>
    
  3. 實體類要支持序列化,也就是實現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);


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM