Mybatis

MyBatis前身是iBatis顾腊,本是Apache的一個(gè)開源的項(xiàng)目

官方網(wǎng)站

http://mybatis.org

ORM框架
實(shí)體類和SQL語句之間建立映射關(guān)系

特點(diǎn)

基于SQL語法,簡單易學(xué)
能了解底層封裝過程
SQL語句封裝在配置文件中,便于統(tǒng)一管理與維護(hù)典蜕,降低######程序的耦合度
方便程序代碼調(diào)試

Mybatis的優(yōu)缺點(diǎn)

優(yōu)點(diǎn):

1.與JDBC相比,減少了50%以上的代碼量
2.最簡單的持久化框架蹲缠,小巧并簡單易學(xué)
3.SQL代碼從程序代碼中徹底分離仗扬,可重用
4.提供XML標(biāo)簽,支持編寫動(dòng)態(tài)SQL
5.提供映射標(biāo)簽育勺,支持對(duì)象與數(shù)據(jù)庫的ORM字段映射

缺點(diǎn):

SQL語句編寫工作量大但荤,對(duì)開發(fā)人員有一定要求
數(shù)據(jù)庫移植性差

MyBatis專注于SQL本身,是一個(gè)足夠靈活的DAO層解決方案涧至,適用于性能要求較高或者需求多變的互聯(lián)網(wǎng)項(xiàng)目

搭建Mybatis的開發(fā)步驟:

1.下載mybatis.jar包并導(dǎo)入工程
2.編寫MyBatis核心配置文件(configuration.xml)
3.創(chuàng)建實(shí)體類-POJO
4.DAO層-SQL映射文件(mapper.xml)
5.創(chuàng)建測試類
       讀取核心配置文件mybatis-config.xml
       創(chuàng)建SqlSessionFactory對(duì)象纱兑,讀取配置文件
       創(chuàng)建SqlSession對(duì)象
       調(diào)用mapper文件進(jìn)行數(shù)據(jù)操作
基本要素:
MyBatis的核心對(duì)象

1.SqlSessionFactoryBuilder
2.SqlSessionFactory
3.SqlSession

mybatis-config.xml 系統(tǒng)核心配置文件
mapper.xml SQL映射文件

核心接口和類的結(jié)構(gòu):

總結(jié):

SqlSessionFactoryBuilder
   用過即丟,推薦作用域范圍:方法體內(nèi)
SqlSessionFactory
   最佳作用域范圍:應(yīng)用的全局作用域
   生命周期與應(yīng)用的生命周期相同
SqlSession
   線程級(jí)
   一個(gè)request請(qǐng)求期間

核心配置文件

mybatis-config.xml 系統(tǒng)核心配置文件
configuration 配置
properties    可以配置在Java 屬性配置文件中
settings    修改 MyBatis 在運(yùn)行時(shí)的行為方式
typeAliases   為 Java 類型命名一個(gè)別名(簡稱)
typeHandlers   類型處理器
objectFactory   對(duì)象工廠
plugins   插件
environments   環(huán)境
environment   環(huán)境變量
transactionManager  事務(wù)管理器
dataSource   數(shù)據(jù)源
mappers    映射器
配置properties元素的兩種方式
通過外部指定的方式(database.properties)化借,實(shí)現(xiàn)動(dòng)態(tài)配置
直接配置為xml潜慎,實(shí)現(xiàn)動(dòng)態(tài)配置
通過外部指定的方式(database.properties),實(shí)現(xiàn)動(dòng)態(tài)配置
配置properties的resource屬性
   <properties resource="database.properties"/>      
   <dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${user}"/>
<property name="password" value="${password}"/>
</dataSource>
直接配置為xml蓖康,實(shí)現(xiàn)動(dòng)態(tài)配置
配置property的name和value
<properties>
    <property name="driver" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://127.0.0.1:3306/sms"/>
    <property name="user" value="root"/>
    <property name="password" value=“123456"/>
 </properties>

<dataSource type="POOLED">
    <property name="driver" value="${driver}"/>
    <property name="url" value="${url}"/>
    <property name="username" value="${user}"/>
    <property name="password" value="${password}"/>
</dataSource>
environments元素
表示配置MyBatis的多套運(yùn)行環(huán)境铐炫,將SQL映射到多個(gè)不同的數(shù)據(jù)庫上
子元素節(jié)點(diǎn):environment,但是必須指定其中一個(gè)為默認(rèn)運(yùn)行環(huán)境(通過default指定)

每個(gè)SqlSessionFactory實(shí)例只能選擇一個(gè)運(yùn)行環(huán)境

<environments default="development">
 <environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
        <property name="driver" value="${driver}"/>
     <property name="url" value="${url}"/>
        <property name="username" value="${user}"/>
        <property name="password" value="${password}"/>
</dataSource>
</environment>
<environment id="test">
</environment>
</environments>

SQL映射文件

MyBatis 真正的強(qiáng)大在于映射語句蒜焊,專注于SQL倒信,功能強(qiáng)大,SQL映射的配置卻是相當(dāng)簡單
SQL映射文件的幾個(gè)頂級(jí)元素(按照定義的順序)
   mapper - namespace
   cache - 配置給定命名空間的緩存
  cache-ref – 從其他命名空間引用緩存配置
  resultMap –用來描述數(shù)據(jù)庫結(jié)果集和對(duì)象的對(duì)應(yīng)關(guān)系
  sql – 可以重用的SQL塊泳梆,也可以被其他語句引用
 insert – 映射插入語句
  update – 映射更新語句
  delete – 映射刪除語句
  select – 映射查詢語句
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末鳖悠,一起剝皮案震驚了整個(gè)濱河市榜掌,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌乘综,老刑警劉巖憎账,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異卡辰,居然都是意外死亡胞皱,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門九妈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來反砌,“玉大人,你說我怎么就攤上這事萌朱⊙缡鳎” “怎么了?”我有些...
    開封第一講書人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵晶疼,是天一觀的道長森渐。 經(jīng)常有香客問我,道長冒晰,這世上最難降的妖魔是什么同衣? 我笑而不...
    開封第一講書人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮壶运,結(jié)果婚禮上耐齐,老公的妹妹穿的比我還像新娘。我一直安慰自己蒋情,他們只是感情好埠况,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著棵癣,像睡著了一般辕翰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上狈谊,一...
    開封第一講書人閱讀 51,258評(píng)論 1 300
  • 那天喜命,我揣著相機(jī)與錄音,去河邊找鬼河劝。 笑死壁榕,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的赎瞎。 我是一名探鬼主播牌里,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼务甥!你這毒婦竟也來了牡辽?” 一聲冷哼從身側(cè)響起喳篇,我...
    開封第一講書人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎态辛,沒想到半個(gè)月后麸澜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡因妙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了票髓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片攀涵。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖洽沟,靈堂內(nèi)的尸體忽然破棺而出以故,到底是詐尸還是另有隱情,我是刑警寧澤裆操,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布怒详,位于F島的核電站,受9級(jí)特大地震影響踪区,放射性物質(zhì)發(fā)生泄漏昆烁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一缎岗、第九天 我趴在偏房一處隱蔽的房頂上張望静尼。 院中可真熱鬧,春花似錦传泊、人聲如沸鼠渺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽拦盹。三九已至,卻和暖如春溪椎,著一層夾襖步出監(jiān)牢的瞬間普舆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來泰國打工校读, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留奔害,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓地熄,卻偏偏與公主長得像华临,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子端考,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容