国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  應(yīng)聘面試  >  Java面試題  > mybatis一級(jí)緩存、二級(jí)緩存

mybatis一級(jí)緩存、二級(jí)緩存

來(lái)源:千鋒教育
發(fā)布人:wjy
時(shí)間: 2022-10-27 16:54:00 1666860840

  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í),通過(guò)存儲(chǔ)的數(shù)據(jù)構(gòu)造成對(duì)象返回。查詢數(shù)據(jù)的時(shí)候,查詢的流程是二級(jí)緩存 > 一級(jí)緩存 > 數(shù)據(jù)庫(kù)。

mybatis一級(jí)緩存、二級(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ù)庫(kù)行為屬性設(shè)置settings。

  - 通過(guò)配置對(duì)象,則可以創(chuàng)建一個(gè)sqlSessionFactoryBuilder對(duì)象。

  - 通過(guò)sqlSessionFactoryBuilder獲得sqlSessionFactory實(shí)例。

  - 通過(guò)sqlSessionFactory實(shí)例創(chuàng)建sqlSession實(shí)例,通過(guò)sqlSession對(duì)數(shù)據(jù)庫(kù)進(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(); /* * 接下來(lái)在這里做很多事情,到目前為止,目的已經(jīng)達(dá)到得到了SqlSession對(duì)象.通過(guò)調(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(); } } }

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
面向?qū)ο缶幊痰奶卣魇鞘裁?請(qǐng)解釋每個(gè)特征

答案:面向?qū)ο缶幊痰奶卣靼ǎ悍庋b(Encapsulation):封裝是將相關(guān)的數(shù)據(jù)和方法組合在一起形成類的機(jī)制。它可以隱藏內(nèi)部實(shí)現(xiàn)細(xì)節(jié),只暴露必要的...詳情>>

2023-07-18 13:56:00
容器是什么?如何理解容器

  容器(Container)是一個(gè)廣泛的概念,指的是一種可以容納其他元素或?qū)ο蟮臄?shù)據(jù)結(jié)構(gòu)或抽象概念。在計(jì)算機(jī)科學(xué)中,容器的概念經(jīng)常出現(xiàn)在數(shù)據(jù)結(jié)...詳情>>

2023-05-08 13:41:00