App下載

w3cschool小編帶你了解mybatis

猿友 2021-01-09 16:57:45 瀏覽數(shù) (2811)
反饋

什么是mybatis:

Mybatis本質是一種半自動化的ORM框架,前身是ibatis,除了要pojo和映射關系之外,還需要些sql語句。

怎么看待ORM框架:

處理矛盾的,java程序員喜歡面向對象開發(fā)和面向接口開發(fā),而數(shù)據(jù)庫是一張張表和一個個庫組成的,這兩者的關系很難調和,而關系型映射解決了這一個問題。

Mybatis映射文件三要素:

  • SQL;
  • 映射規(guī)則;
  • Pojo。

為什么要用mybatis而不用hibernate?

在我們互聯(lián)網的環(huán)境里面, 我們經常要面對海量數(shù)據(jù),所以我們要基于底層的調優(yōu)能力,就是sql語句。而hibernate生成的sql語句很不透明。

Mybatis核心流程三大階段:

  • 初始化階段,讀取XML配置文件和注解中的配置信息,創(chuàng)建解析對象,并完成各個模塊的初始化工作。就是把我們的配置文件加載到內存里面去。在sqlSession初始化的時候加載到內存中去的;
  • 代理階段,封裝iBatis的編程模型,使用mapper接口開發(fā)的初始化工作;
  • 數(shù)據(jù)讀寫階段,通過SqlSession完成SQL的解析,參數(shù)的映射,SQL的執(zhí)行,結果的反射解析過程。

SqlSession

SqlSession意味著創(chuàng)建數(shù)據(jù)庫會話,代表了一次與數(shù)據(jù)庫的連接;

是mybatis對外提供數(shù)據(jù)訪問的主要API;

實際上SqlSession的功能都是基于Excutor來實現(xiàn)的。

Mybatis的兩種編程模型Mybatis封裝了ibatis編程模型,使用sqlsession對外提供數(shù)據(jù)庫的訪問。還有一種是使用mapper接口編程,就可以訪問數(shù)據(jù)庫

Mybatis和ibatis的區(qū)別

Mybatis前身是ibatis的,ibatis之前是Apache旗下的產品,后來到了谷歌旗下,但是谷歌發(fā)現(xiàn)ibatis實現(xiàn)起來很麻煩,還需要維護靜態(tài)變量,并且沒有業(yè)務含義。所以谷歌改成了mybatis,通過面向接口的方式,讓所有代碼有了業(yè)務含義,屏蔽掉了底層代碼的復雜性。

為什么使用mapper接口就可以對數(shù)據(jù)庫進行訪問了呢?

其實最后它還是轉成了底層的ibatis執(zhí)行方法,它會使用配置文件解讀+動態(tài)代理, 找到session中的對應方法執(zhí)行,找到方法的命名空間和方法名。傳遞參數(shù)。

業(yè)務流程還是首先要實例化sqlssessionFactory,加載數(shù)據(jù)庫配置文件以及mapper.xml到configuration對象。然后獲取sqlsession對象。然后通過動態(tài)代理跨越面向接口編程和ibatis編程的鴻溝,最后遵循jdbc的規(guī)范,通過底層的四大對象合作完成功能。

推薦好課:

Mybatis3.x從入門到精通

MyBatis 教程

Mybatis常見面試題


0 人點贊