1. 一級(jí)緩存;指的是mybatis中sqlSession對(duì)象的緩存,當(dāng)我們執(zhí)行查詢以后,查詢的結(jié)果會(huì)同時(shí)存入sqlSession中,再次查詢的時(shí)候,先去sqlSession中查詢,有的話直接拿出,當(dāng)sqlSession消失時(shí),mybatis的一級(jí)緩存也就消失了,當(dāng)調(diào)用sqlSession的修改、添加、刪除、commit()、close()等方法時(shí),會(huì)清空一級(jí)緩存。
2. 二級(jí)緩存:指的是mybatis中的sqlSessionFactory對(duì)象的緩存,由同一個(gè)sqlSessionFactory對(duì)象創(chuàng)建的sqlSession共享其緩存,但是其中緩存的是數(shù)據(jù)而不是對(duì)象。當(dāng)命中二級(jí)緩存時(shí),通過存儲(chǔ)的數(shù)據(jù)構(gòu)造成對(duì)象返回。查詢數(shù)據(jù)的時(shí)候,查詢的流程是二級(jí)緩存 > 一級(jí)緩存 > 數(shù)據(jù)庫。
3. 二級(jí)緩存執(zhí)行時(shí)機(jī),如果開啟了二級(jí)緩存,sqlSession進(jìn)行close()后,才會(huì)把sqlSession一級(jí)緩存中的數(shù)據(jù)添加到二級(jí)緩存中,為了將緩存數(shù)據(jù)取出執(zhí)行反序列化,還需要將要緩存的pojo實(shí)現(xiàn)Serializable接口,因?yàn)槎?jí)緩存數(shù)據(jù)存儲(chǔ)介質(zhì)多種多樣,不一定只存在內(nèi)存中,也可能存在硬盤中。
4. mybatis執(zhí)行步驟,mybatis框架主要是圍繞sqlSessionFactory進(jìn)行的,
具體的步驟:
- 定義一個(gè)configuration對(duì)象,其中包含數(shù)據(jù)源、事務(wù)、mapper文件資源以及影響數(shù)據(jù)庫行為屬性設(shè)置settings。
- 通過配置對(duì)象,則可以創(chuàng)建一個(gè)sqlSessionFactoryBuilder對(duì)象。
- 通過sqlSessionFactoryBuilder獲得sqlSessionFactory實(shí)例。
- 通過sqlSessionFactory實(shí)例創(chuàng)建sqlSession實(shí)例,通過sqlSession對(duì)數(shù)據(jù)庫進(jìn)行操作。
5. 代碼實(shí)例
5.1 mybatis-config.xml文件內(nèi)容
5.2 MyBatisTest類 public class MyBatisTest { public static void main(String[] args) { try { //讀取mybatis-config.xml文件 InputStream resourceAsStream = Resources.getResourceAsStream("mybatis-config.xml");
//初始化mybatis,創(chuàng)建SqlSessionFactory類的實(shí)例 SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
//創(chuàng)建session實(shí)例SqlSession session = sqlSessionFactory.openSession(); /* * 接下來在這里做很多事情,到目前為止,目的已經(jīng)達(dá)到得到了SqlSession對(duì)象.通過調(diào)用SqlSession里面的方法, * 可以測(cè)試MyBatis和Dao層接口方法之間的正確性,當(dāng)然也可以做別的很多事情,在這里就不列舉了 */
//插入數(shù)據(jù) User user = new User(); user.setC_password("123"); user.setC_username("123"); user.setC_salt("123"); //個(gè)參數(shù)為方法的完全限定名:位置信息+映射文件當(dāng)中的id session.insert("com.cn.dao.UserMapping.insertUserInformation", user);
//提交事務(wù) session.commit(); //關(guān)閉session session.close(); } catch (IOException e) { e.printStackTrace(); } } }