7.MyBatis如何無(wú)縫對(duì)接Spring

1.為什么會(huì)出現(xiàn)MyBatis-Spring

Spring框架與MyBatis框架是Java互聯(lián)網(wǎng)技術(shù)的主流框架。但是如何將MyBatis無(wú)縫整合到Spring框架中呢?這時(shí)候就誕生了MyBatis-Spring经宏。使用這個(gè)類(lèi)庫(kù)中得類(lèi),Spring將會(huì)加載必要的MyBatis工廠(chǎng)類(lèi)和session類(lèi)驯击。

Spring3.0也僅僅支持ibatis2.0烁兰。本來(lái)將MyBatis3的支持添加到Spring3.0中。而不幸徊都,Spring3.0的開(kāi)發(fā)在MyBatis3.0官方發(fā)布前就結(jié)束了沪斟。因?yàn)镾pring開(kāi)發(fā)團(tuán)隊(duì)不想發(fā)布一個(gè)非發(fā)布版的MyBatis的整合支持。就放棄了對(duì)MyBatis的支持。

隨著Spring越來(lái)越成為java事實(shí)標(biāo)準(zhǔn)的技術(shù)框架主之。Spring 4.0 移除了對(duì)iBatis的直接支持择吊。MyBatis團(tuán)隊(duì)開(kāi)發(fā)出來(lái)了基于Spring的MyBatis整合Jar---MyBatis-Spring。

2.使用MyBatis-Spring的好處

  • 1.使得業(yè)務(wù)層和模型層得到更好的分離槽奕。再Spring框架中MyBatis也更加簡(jiǎn)單几睛,節(jié)約不少的代碼
  • 2.甚至不需要顯示的使用SqlSessionFactory、SqlSessiond等對(duì)象

3.MyBatis-Spring組成部分

  • 1.配置數(shù)據(jù)源
  • 2.配置SqlSessionFactory
  • 3.配置SqlSessionTemplate
  • 4.配置Mapper
  • 5.事務(wù)處理

MyBatis中要構(gòu)建SqlSessionFactory對(duì)象粤攒,讓它產(chǎn)生SqlSession,而在MyBatis-Spring項(xiàng)目中SqlSession的使用是通過(guò)SqlSessionTemplate來(lái)實(shí)現(xiàn)的所森,它提供了對(duì)SqlSession操作的封裝。所以可以通過(guò)SqlSessionTemplate可以得到Mapper夯接。

4.在Spring MVC中配置

4.1 配置SqlSessionFactoryBean

在基本的 MyBatis中,session工廠(chǎng)可以使用SqlSessionFactoryBuilder 來(lái)創(chuàng)建焕济。而在 MyBatis-Spring 中,則使用 SqlSessionFactoryBean 來(lái)替代。

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  <property name="dataSource" ref="dataSource" />
</bean>

注意點(diǎn)

  • SqlSessionFactory 有一個(gè)單獨(dú)的必須屬性,就是 JDBC 的 DataSource

在SqlSessionFactoryBean的返回getObject的時(shí)候盔几,有個(gè)驗(yàn)證晴弃。

  @Override
  public SqlSessionFactory getObject() throws Exception {
    if (this.sqlSessionFactory == null) {
      afterPropertiesSet();
    }

    return this.sqlSessionFactory;
  }
  @Override
  public void afterPropertiesSet() throws Exception {
    notNull(dataSource, "Property 'dataSource' is required");
    notNull(sqlSessionFactoryBuilder, "Property 'sqlSessionFactoryBuilder' is required");
    state((configuration == null && configLocation == null) || !(configuration != null && configLocation != null),
              "Property 'configuration' and 'configLocation' can not specified with together");

    this.sqlSessionFactory = buildSqlSessionFactory();
  }

4.2配置datasource

這里我們使用的是阿里巴巴的數(shù)據(jù)庫(kù)連接池。https://github.com/alibaba/druid

compile group: 'com.alibaba', name: 'druid', version: '1.1.2'
<!--阿里巴巴的數(shù)據(jù)庫(kù)連接池-->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
    <!-- 基本屬性 url逊拍、user肝匆、password -->
    <property name="url" value="${jdbc_url}"/>
    <property name="username" value="${jdbc_user}"/>
    <property name="password" value="${jdbc_password}"/>
</bean>

4.3配置數(shù)據(jù)庫(kù)鏈接屬性

在resource目錄下創(chuàng)建properties文件夾,并創(chuàng)建datasource.properties

jdbc_url=jdbc:mysql://localhost:3306/cnblogs?serverTimezone=Asia/Shanghai&characterEncoding=utf8
jdbc_user=root
jdbc_password=root

使用阿里巴巴的數(shù)據(jù)庫(kù)連接池是無(wú)需配置數(shù)據(jù)庫(kù)驅(qū)動(dòng)顺献。是根據(jù)url的前綴來(lái)判斷的

4.4配置Spring加載配置屬性及配置替換動(dòng)態(tài)標(biāo)簽

<!--加載配置文件路徑-->
<bean id="configProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
    <property name="location" value="classpath:properties/datasource.properties"></property>
</bean>

<!--獲取配置屬性之后動(dòng)態(tài)替換標(biāo)簽-->
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer">
    <property name="properties" ref="configProperties"/>
</bean>

4.5配置Spring自動(dòng)創(chuàng)建Mapper接口的bean

MyBatis-Spring提供了一個(gè)轉(zhuǎn)換器MapperScannerConfigurer旗国,可以將映射接口轉(zhuǎn)換為Spring容器中Bean。這樣就可以在代碼中注入映射的bean

<!--采用自動(dòng)掃描方式創(chuàng)建Mapper Bean-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="basePackage" value="com.cnblogs.dao"></property>
</bean>

basePackage屬性是讓你為映射器接口文件設(shè)置基本的包路徑注整。 你可以使用分號(hào)或逗號(hào)作為分隔符設(shè)置多于一個(gè)的包路徑能曾。每個(gè)映射器將會(huì)在指定的包路徑中遞歸地被搜索到。

4.6配置事務(wù)

MyBatis和Spring結(jié)合后是使用Spring AOP去管理事務(wù)的肿轨,使用Spring AOP是相當(dāng)?shù)暮?jiǎn)單的寿冕,它分為聲明式事務(wù)和編程性事務(wù)。大部分場(chǎng)景下使用聲明式事務(wù)就可以了椒袍。

  • 引入Jar包
compile group: 'org.springframework', name: 'spring-tx', version: '4.3.10.RELEASE'
compile group: 'org.springframework', name: 'spring-jdbc', version: '4.3.10.RELEASE'
<!--事務(wù)管理器-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource" />
</bean>

<!--使用聲明式事務(wù)管理方式-->
<tx:annotation-driven transaction-manager="transactionManager"/>

5.完整的Spring xml配置及引用的Jar包

  • 引入的Jar列表
compile group: 'org.springframework', name: 'spring-webmvc', version: '4.3.10.RELEASE'
compile group: 'org.springframework', name: 'spring-tx', version: '4.3.10.RELEASE'
compile group: 'org.springframework', name: 'spring-jdbc', version: '4.3.10.RELEASE'
compile group: 'javax.servlet', name: 'javax.servlet-api', version: '3.1.0'
compile group: 'org.mybatis', name: 'mybatis-spring', version: '1.3.1'
compile group: 'org.mybatis', name: 'mybatis', version: '3.4.5'
compile group: 'mysql', name: 'mysql-connector-java', version: '6.0.6'
compile group: 'com.alibaba', name: 'druid', version: '1.1.2'
  • Spring的配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/context/spring-context.xsd
       http://www.springframework.org/schema/mvc
       http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">

    <!--spring可以自動(dòng)去掃描base-pack下面的包或者子包下面的Java文件-->
    <context:component-scan base-package="com.cnblogs.controller,com.cnblogs.service,com.cnblogs.dao"/>

    <!--自動(dòng)注冊(cè)RequestMappingHandlerMapping與RequestMappingHandlerAdpter-->
    <mvc:annotation-driven/>

    <!-- 對(duì)靜態(tài)資源文件的訪(fǎng)問(wèn)-->
    <mvc:default-servlet-handler/>

    <!--加載配置文件路徑-->
    <bean id="configProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
        <property name="location" value="classpath:properties/datasource.properties"></property>
    </bean>

    <!--獲取配置屬性之后動(dòng)態(tài)替換標(biāo)簽-->
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer">
        <property name="properties" ref="configProperties"/>
    </bean>

    <!--阿里巴巴的數(shù)據(jù)庫(kù)連接池-->
    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
        <!-- 基本屬性 url驼唱、user、password -->
        <property name="url" value="${jdbc_url}"/>
        <property name="username" value="${jdbc_user}"/>
        <property name="password" value="${jdbc_password}"/>
    </bean>

    <!--構(gòu)建SqlSessionFactory-->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="configLocation" value="classpath:config/mybatis-config.xml"/>
        <property name="mapperLocations" value="classpath:mappers/*.xml"/>
    </bean>

    <!--采用自動(dòng)掃描方式創(chuàng)建Mapper Bean-->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.cnblogs.dao"></property>
    </bean>

    <!--事務(wù)管理器-->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource" />
    </bean>

    <!--使用聲明式事務(wù)管理方式-->
    <tx:annotation-driven transaction-manager="transactionManager"/>

    <!--視圖解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/content"></property>
        <property name="suffix" value=".jsp"></property>
    </bean>
</beans>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末驹暑,一起剝皮案震驚了整個(gè)濱河市玫恳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌优俘,老刑警劉巖京办,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異帆焕,居然都是意外死亡惭婿,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)财饥,“玉大人换吧,你說(shuō)我怎么就攤上這事≡啃牵” “怎么了式散?”我有些...
    開(kāi)封第一講書(shū)人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)打颤。 經(jīng)常有香客問(wèn)我暴拄,道長(zhǎng),這世上最難降的妖魔是什么编饺? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任乖篷,我火速辦了婚禮,結(jié)果婚禮上透且,老公的妹妹穿的比我還像新娘撕蔼。我一直安慰自己,他們只是感情好秽誊,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布鲸沮。 她就那樣靜靜地躺著,像睡著了一般锅论。 火紅的嫁衣襯著肌膚如雪讼溺。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,158評(píng)論 1 308
  • 那天最易,我揣著相機(jī)與錄音怒坯,去河邊找鬼。 笑死藻懒,一個(gè)胖子當(dāng)著我的面吹牛剔猿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播嬉荆,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼归敬,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了鄙早?” 一聲冷哼從身側(cè)響起汪茧,我...
    開(kāi)封第一講書(shū)人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蝶锋,沒(méi)想到半個(gè)月后陆爽,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡扳缕,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片躯舔。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡驴剔,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出粥庄,到底是詐尸還是另有隱情丧失,我是刑警寧澤,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布惜互,位于F島的核電站布讹,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏训堆。R本人自食惡果不足惜描验,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望坑鱼。 院中可真熱鬧膘流,春花似錦、人聲如沸鲁沥。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)画恰。三九已至彭谁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間允扇,已是汗流浹背马靠。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蔼两,地道東北人甩鳄。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像额划,于是被迫代替她去往敵國(guó)和親妙啃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

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

  • 1. 簡(jiǎn)介 1.1 什么是 MyBatis 俊戳? MyBatis 是支持定制化 SQL揖赴、存儲(chǔ)過(guò)程以及高級(jí)映射的優(yōu)秀的...
    笨鳥(niǎo)慢飛閱讀 5,527評(píng)論 0 4
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)抑胎,斷路器燥滑,智...
    卡卡羅2017閱讀 134,693評(píng)論 18 139
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,838評(píng)論 6 342
  • Spring 技術(shù)筆記Day 1 預(yù)熱知識(shí)一、 基本術(shù)語(yǔ)Blob類(lèi)型阿逃,二進(jìn)制對(duì)象Object Graph:對(duì)象圖...
    OchardBird閱讀 978評(píng)論 0 2
  • 年少時(shí)我們都曾有過(guò)太多的想象,總覺(jué)得生活如同自己在武俠小說(shuō)里看到的那樣搀菩,成年之后可以快意恩仇呕臂,可以做喬峰 令狐沖 ...
    孫道強(qiáng)閱讀 1,088評(píng)論 0 1