久久青草精品A片狠狠,日韩欧美视频一区二区,亚洲国码AV日韩,国产精品黄在

Mybatis工作流程及其原理

2021-04-30 13:55:03 1451

一、MyBatis的重要組件

Mybatis底層封裝了JDBC,使用了動(dòng)態(tài)代理模式。

1.SqlSessionFactoryBuilder (構(gòu)造器):使用Builder模式根據(jù)mybatis-config.xml配置或者代碼來(lái)生成SqISessionFactory。

2.SqlSessionFactory (工廠接口):使用工廠模式生成SqlSession。

3.SqlSession (會(huì)話):一個(gè)既可以發(fā)送 SQL 執(zhí)行返回結(jié)果,也可以獲取Mapper的接口。

4.SQL Mapper (映射器):它由一個(gè)Java接口和XML文件(或注解)構(gòu)成,需要給出對(duì)應(yīng)的SQL和映射規(guī)則,它負(fù)責(zé)發(fā)送SQL去執(zhí)行,并返回結(jié)果。

5.Executor(執(zhí)行器)

二、Mybatis工作流程

1.通過(guò)SqlSessionFactoryBuilder創(chuàng)建SqlSessionFactory對(duì)象

2.通過(guò)SqlSessionFactory創(chuàng)建SqlSession對(duì)象

3.通過(guò)SqlSession拿到Mapper代理對(duì)象

4.通過(guò)MapperProxy調(diào)用Mapper中增刪改查的方法

三、Mybatis與hibernate區(qū)別 參考:MyBatis與Hibernate區(qū)別

1.hibernate是全自動(dòng),而mybatis是半自動(dòng)

hibernate完全可以通過(guò)對(duì)象關(guān)系模型實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)的操作,擁有完整的JavaBean對(duì)象與數(shù)據(jù)庫(kù)的映射結(jié)構(gòu)來(lái)自動(dòng)生成sql。而mybatis僅有基本的字段映射,對(duì)象數(shù)據(jù)以及對(duì)象實(shí)際關(guān)系仍然需要通過(guò)手寫(xiě)sql來(lái)實(shí)現(xiàn)和管理。

2.hibernate數(shù)據(jù)庫(kù)移植性遠(yuǎn)大于mybatis

hibernate通過(guò)它強(qiáng)大的映射結(jié)構(gòu)和hql語(yǔ)言,大大降低了對(duì)象與數(shù)據(jù)庫(kù)(Oracle、MySQL等)的耦合性,而mybatis由于需要手寫(xiě)sql,因此與數(shù)據(jù)庫(kù)的耦合性直接取決于程序員寫(xiě)sql的方法,如果sql不具通用性而用了很多某數(shù)據(jù)庫(kù)特性的sql語(yǔ)句的話,移植性也會(huì)隨之降低很多,成本很高。

3.hibernate擁有完整的日志系統(tǒng),mybatis則欠缺一些

hibernate日志系統(tǒng)非常健全,涉及廣泛,包括:sql記錄、關(guān)系異常、優(yōu)化警告、緩存提示、臟數(shù)據(jù)警告等;而mybatis則除了基本記錄功能外,功能薄弱很多。

4.mybatis相比hibernate需要關(guān)心很多細(xì)節(jié)

hibernate配置要比mybatis復(fù)雜的多,學(xué)習(xí)成本也比mybatis高。但也正因?yàn)閙ybatis使用簡(jiǎn)單,才導(dǎo)致它要比hibernate關(guān)心很多技術(shù)細(xì)節(jié)。mybatis由于不用考慮很多細(xì)節(jié),開(kāi)發(fā)模式上與傳統(tǒng)jdbc區(qū)別很小,因此很容易上手并開(kāi)發(fā)項(xiàng)目,但忽略細(xì)節(jié)會(huì)導(dǎo)致項(xiàng)目前期bug較多,因而開(kāi)發(fā)出相對(duì)穩(wěn)定的軟件很慢,而開(kāi)發(fā)出軟件卻很快。hibernate則正好與之相反。但是如果使用hibernate很熟練的話,實(shí)際上開(kāi)發(fā)效率絲毫不差于甚至超越mybatis。

5.sql直接優(yōu)化上,mybatis要比hibernate方便很多

由于mybatis的sql都是寫(xiě)在xml里,因此優(yōu)化sql比hibernate方便很多。而hibernate的sql很多都是自動(dòng)生成的,無(wú)法直接維護(hù)sql;雖有hql,但功能還是不及sql強(qiáng)大,見(jiàn)到報(bào)表等變態(tài)需求時(shí),hql也歇菜,也就是說(shuō)hql是有局限的;hibernate雖然也支持原生sql,但開(kāi)發(fā)模式上卻與orm不同,需要轉(zhuǎn)換思維,因此使用上不是非常方便。總之寫(xiě)sql的靈活度上hibernate不及mybatis。

6.緩存機(jī)制上,hibernate要比mybatis更好一些

MyBatis的二級(jí)緩存配置都是在每個(gè)具體的表-對(duì)象映射中進(jìn)行詳細(xì)配置,這樣針對(duì)不同的表可以自定義不同的緩存機(jī)制。并且Mybatis可以在命名空間中共享相同的緩存配置和實(shí)例,通過(guò)Cache-ref來(lái)實(shí)現(xiàn)。

而Hibernate對(duì)查詢對(duì)象有著良好的管理機(jī)制,用戶無(wú)需關(guān)心SQL。所以在使用二級(jí)緩存時(shí)如果出現(xiàn)臟數(shù)據(jù),系統(tǒng)會(huì)報(bào)出錯(cuò)誤并提示。



提交成功!非常感謝您的反饋,我們會(huì)繼續(xù)努力做到更好!

這條文檔是否有幫助解決問(wèn)題?

非常抱歉未能幫助到您。為了給您提供更好的服務(wù),我們很需要您進(jìn)一步的反饋信息:

在文檔使用中是否遇到以下問(wèn)題: