MyBatis前身是iBatis顾腊,本是Apache的一個(gè)開源的項(xiàng)目
官方網(wǎng)站
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 – 映射查詢語句