Mybatis

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

官方網(wǎng)站

http://mybatis.org

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

特點(diǎn)

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

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

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

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

缺點(diǎn):

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

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)建測(cè)試類
       讀取核心配置文件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
   用過(guò)即丟,推薦作用域范圍:方法體內(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è)別名(簡(jiǎn)稱)
typeHandlers   類型處理器
objectFactory   對(duì)象工廠
plugins   插件
environments   環(huán)境
environment   環(huán)境變量
transactionManager  事務(wù)管理器
dataSource   數(shù)據(jù)源
mappers    映射器
配置properties元素的兩種方式
通過(guò)外部指定的方式(database.properties),實(shí)現(xiàn)動(dòng)態(tài)配置
直接配置為xml,實(shí)現(xiàn)動(dòng)態(tài)配置
通過(guò)外部指定的方式(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ù)庫(kù)上
子元素節(jié)點(diǎn):environment,但是必須指定其中一個(gè)為默認(rèn)運(yùn)行環(huán)境(通過(guò)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)大在于映射語(yǔ)句,專注于SQL,功能強(qiáng)大,SQL映射的配置卻是相當(dāng)簡(jiǎn)單
SQL映射文件的幾個(gè)頂級(jí)元素(按照定義的順序)
   mapper - namespace
   cache - 配置給定命名空間的緩存
  cache-ref – 從其他命名空間引用緩存配置
  resultMap –用來(lái)描述數(shù)據(jù)庫(kù)結(jié)果集和對(duì)象的對(duì)應(yīng)關(guān)系
  sql – 可以重用的SQL塊,也可以被其他語(yǔ)句引用
 insert – 映射插入語(yǔ)句
  update – 映射更新語(yǔ)句
  delete – 映射刪除語(yǔ)句
  select – 映射查詢語(yǔ)句
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容