一、Mybatis是什么
?
MyBatis是一個(gè)支持普通SQL查詢,存儲(chǔ)過(guò)程和高級(jí)映射的優(yōu)秀持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數(shù)的手工設(shè)置以及對(duì)結(jié)果集的檢索封裝。MyBatis可以使用簡(jiǎn)單的XML或注解用于配置和原始映射,將接口和Java的POJO(Plain Old Java Objects,普通的Java對(duì)象)映射成數(shù)據(jù)庫(kù)中的記錄。
1、Mybatis實(shí)現(xiàn)了接口綁定,使用更加方便。
在ibatis2.x中我們需要在DAO的實(shí)現(xiàn)類中指定具體對(duì)應(yīng)哪個(gè)xml映射文件, 而Mybatis實(shí)現(xiàn)了DAO接口與xml映射文件的綁定,自動(dòng)為我們生成接口的具體實(shí)現(xiàn),使用起來(lái)變得更加省事和方便。
2、對(duì)象關(guān)系映射的改進(jìn),效率更高
3、MyBatis采用功能強(qiáng)大的基于OGNL的表達(dá)式來(lái)消除其他元素。
對(duì)于IBatis與MyBatis的區(qū)別就不再多說(shuō)了,感興趣的朋友可以研究一下
MyBatis的框架架構(gòu)
?
看到Mybatis的框架圖,可以清晰的看到Mybatis的整體核心對(duì)象,我更喜歡用自己的圖來(lái)表達(dá)Mybatis的整個(gè)的執(zhí)行流程。如下圖所示:
?
原理詳解:
MyBatis應(yīng)用程序根據(jù)XML配置文件創(chuàng)建SqlSessionFactory,SqlSessionFactory在根據(jù)配置,配置來(lái)源于兩個(gè)地方,一處是配置文件,一處是Java代碼的注解,獲取一個(gè)SqlSession。SqlSession包含了執(zhí)行sql所需要的所有方法,可以通過(guò)SqlSession實(shí)例直接運(yùn)行映射的sql語(yǔ)句,完成對(duì)數(shù)據(jù)的增刪改查和事務(wù)提交等,用完之后關(guān)閉SqlSession。
MyBatis的優(yōu)缺點(diǎn)詳解
優(yōu)點(diǎn):
1、簡(jiǎn)單易學(xué)
mybatis本身就很小且簡(jiǎn)單。沒(méi)有任何第三方依賴,最簡(jiǎn)單安裝只要兩個(gè)jar文件+配置幾個(gè)sql映射文件易于學(xué)習(xí),易于使用,通過(guò)文檔和源代碼,可以比較完全的掌握它的設(shè)計(jì)思路和實(shí)現(xiàn)
2、靈活
mybatis不會(huì)對(duì)應(yīng)用程序或者數(shù)據(jù)庫(kù)的現(xiàn)有設(shè)計(jì)強(qiáng)加任何影響。 sql寫(xiě)在xml里,便于統(tǒng)一管理和優(yōu)化。通過(guò)sql基本上可以實(shí)現(xiàn)我們不使用數(shù)據(jù)訪問(wèn)框架可以實(shí)現(xiàn)的所有功能,或許更多。
通過(guò)提供DAL層,將業(yè)務(wù)邏輯和數(shù)據(jù)訪問(wèn)邏輯分離,使系統(tǒng)的設(shè)計(jì)更清晰,更易維護(hù),更易單元測(cè)試。sql和代碼的分離,提高了可維護(hù)性。
4、提供映射標(biāo)簽,支持對(duì)象與數(shù)據(jù)庫(kù)的orm字段關(guān)系映射
5、提供對(duì)象關(guān)系映射標(biāo)簽,支持對(duì)象關(guān)系組建維護(hù)
6、提供xml標(biāo)簽,支持編寫(xiě)動(dòng)態(tài)sql。
缺點(diǎn):
1、編寫(xiě)SQL語(yǔ)句時(shí)工作量很大,尤其是字段多、關(guān)聯(lián)表多時(shí),更是如此。
2、SQL語(yǔ)句依賴于數(shù)據(jù)庫(kù),導(dǎo)致數(shù)據(jù)庫(kù)移植性差,不能更換數(shù)據(jù)庫(kù)。
3、框架還是比較簡(jiǎn)陋,功能尚有缺失,雖然簡(jiǎn)化了數(shù)據(jù)綁定代碼,但是整個(gè)底層數(shù)據(jù)庫(kù)查詢實(shí)際還是要自己寫(xiě)的,工作量也比較大,而且不太容易適應(yīng)快速數(shù)據(jù)庫(kù)修改。
4、二級(jí)緩存機(jī)制不佳
小結(jié)
mybatis的優(yōu)點(diǎn)同樣是mybatis的缺點(diǎn),正因?yàn)閙ybatis使用簡(jiǎn)單,數(shù)據(jù)的可靠性、完整性的瓶頸便更多依賴于程序員對(duì)sql的使用水平上了。sql寫(xiě)在xml里,雖然方便了修改、優(yōu)化和統(tǒng)一瀏覽,但可讀性很低,調(diào)試也非常困難,也非常受限。
mybatis沒(méi)有hibernate那么強(qiáng)大,但是mybatis最大的優(yōu)點(diǎn)就是簡(jiǎn)單小巧易于上手,方便瀏覽修改sql語(yǔ)句。
Mybatis框架認(rèn)知
是別人開(kāi)發(fā)的一種半成品軟件,可以用來(lái)通過(guò)定制輔助快速開(kāi)發(fā)是工具.
1.mybatis入門簡(jiǎn)介
java程序都是通過(guò)jdbc連接數(shù)據(jù)庫(kù)的,
jdbc連接數(shù)據(jù)庫(kù)分為這幾步:
.注冊(cè)驅(qū)動(dòng),連接數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)信息.
.操作connection,打開(kāi)statement對(duì)象.
.通過(guò)statement執(zhí)行sql語(yǔ)句,返回結(jié)果到resultset對(duì)象
.使用resultset對(duì)象讀取數(shù)據(jù),然后通過(guò)代碼轉(zhuǎn)換為具體的POJO對(duì)象(普通的java對(duì)象)
.關(guān)閉數(shù)據(jù)庫(kù)相關(guān)資源.
缺點(diǎn):
工作量大,造成的廢管代碼多,還需要對(duì)異常進(jìn)行捕捉處理.
由于jdbc存在的缺陷,于是提出了對(duì)象關(guān)系映射(ORM Object Relational Mapping),ORM模型就是數(shù)據(jù)庫(kù)的表和POJO對(duì)象的相互映射.
java ———>映射 —–>數(shù)據(jù)
程序《——– 配置《——庫(kù)
Hibernate框架,就是基礎(chǔ)ORM模型進(jìn)行搭建的.他是一個(gè)全自動(dòng)映射框架,與此相比.
mybatis框架,是一個(gè)半自動(dòng)框架mybatis框架.優(yōu)化了Hibernate框架的缺點(diǎn).
Hibernate框架缺點(diǎn):
.全表映射帶來(lái)的不便,比如更新是需要發(fā)送所有字段.
.無(wú)法根據(jù)不同的條件組裝不同的sql.
.對(duì)多表關(guān)聯(lián)和復(fù)雜sql查詢支持較差,需要自己寫(xiě)sql,返回后,需要自己將數(shù)據(jù)組裝成POJO.
.不能有效支持存儲(chǔ)過(guò)程.
.雖有HQL,但是性能較差,大型互聯(lián)網(wǎng)系統(tǒng)往往需要優(yōu)化sql.而Hibernate做不到.
mybatis和hibernate是基于持久層的開(kāi)發(fā)框架.
mybatis所需要的映射文件包含三部分:
SQL
映射規(guī)則
POJO
mybatis《—- pojo—->注解 SQL_Mapper —->數(shù)據(jù)
應(yīng)用程序—->對(duì)象《—- 接口 xml映射文件 《—-庫(kù)
mybatis的基本構(gòu)成
.SqlSessionFactoryBuilder(構(gòu)造器):他會(huì)根據(jù)配置信息或者代碼來(lái)生成SqlSessionFactory(工廠接口).
.SqlSessionFactory:依靠工廠來(lái)生成SqlSession(會(huì)話).
.SqlSession:是一個(gè)既可以發(fā)送SQL去執(zhí)行并返回結(jié)果,也可以獲取Mapper接口.
.Sql Mapper:他是MyBatis新設(shè)計(jì)的組件,他是由一個(gè)java接口和xml文件(或者注解)構(gòu)成的.需要給出對(duì)應(yīng)的SQL和映射規(guī)則,
他負(fù)責(zé)發(fā)送SQL去執(zhí)行,并返回執(zhí)行結(jié)果.
簡(jiǎn)單的mybatis使用
首先將下載mybatis包,將eclipse包放入myeclipse底下dropins中.然后將generator.xml放入你的項(xiàng)目中將數(shù)據(jù)庫(kù)配置、項(xiàng)目配置等更改完畢.
在generator.xml文件上點(diǎn)擊右鍵,生成dao層、實(shí)體類和mapper映射文件.
設(shè)計(jì)并創(chuàng)建對(duì)應(yīng)的表結(jié)構(gòu)
編程調(diào)用映射文件中的sql語(yǔ)句進(jìn)行數(shù)據(jù)的insert操作
// 通過(guò)工具類Resouces獲取讀取核心配置文件的輸入流
InputStream is = Resources.getResourceAsStream(“mybatis-config.xml”);
// 通過(guò)SqlSessionFactory的構(gòu)建器解析讀取核心配置文件,并創(chuàng)建SqlSessionFactory對(duì)象
SqlSessionFactory fac = new SqlSessionFactoryBuilder().build(is);
// 獲取SqlSession對(duì)象,這個(gè)對(duì)象一般充當(dāng)實(shí)體管理器的功能,提供了一般的CRUD的方法
SqlSession session = fac.openSession();
StudentBean sb1 = new StudentBean();
sb1.setName(“張三”);
sb1.setBirth(new java.sql.Date(89, 2, 3));
sb1.setSex(false);
// 通過(guò)sqlSession對(duì)象調(diào)用映射元文件中的《insert>定義執(zhí)行數(shù)據(jù)的插入操作,參數(shù)1為《insert>的名稱
int len = session.insert(“com.yan.entity.StudentBean.insert”, sb1);// 返回值為所執(zhí)行的SQL語(yǔ)句的受影響行數(shù)
//mybatis框架默認(rèn)采用事務(wù)回滾,如果需要修改生效,則必須進(jìn)行手動(dòng)提交處理
session.commit();
session.close();
評(píng)論