激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

香港云服务器
服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - MyBatis無(wú)縫對(duì)接Spring的方法

MyBatis無(wú)縫對(duì)接Spring的方法

2020-12-25 12:24落葉飛逝的戀 Java教程

Spring框架與MyBatis框架是Java互聯(lián)網(wǎng)技術(shù)的主流框架。那么mybatis如何無(wú)縫對(duì)接spring呢?下面通過(guò)本文給大家介紹,需要的的朋友參考下吧

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工廠類(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工廠可以使用SqlSessionFactoryBuilder 來(lái)創(chuàng)建。而在 MyBatis-Spring 中,則使用 SqlSessionFactoryBean 來(lái)替代。

?
1
2
3
<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)證。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
@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

?
1
2
3
4
5
6
7
8
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

?
1
2
3
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)簽

?
1
2
3
4
5
6
7
8
<!--加載配置文件路徑-->
<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

?
1
2
3
4
<!--采用自動(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包

?
1
2
3
4
5
6
7
8
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列表

?
1
2
3
4
5
6
7
8
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的配置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
<?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)資源文件的訪問(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>

總結(jié)

以上所述是小編給大家介紹的MyBatis無(wú)縫對(duì)接Spring的方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)服務(wù)器之家網(wǎng)站的支持!

原文鏈接:http://www.jianshu.com/p/213479f25d84

延伸 · 閱讀

精彩推薦
881
主站蜘蛛池模板: 日本aaaa片毛片免费观看视频 | 91精品国产九九九久久久亚洲 | 免费放黄网站在线播放 | 亚洲网站一区 | 国产成人在线一区二区 | 免费观看欧美一级片 | 久久另类视频 | 成人国产精品齐天大性 | 久久国产精品久久久久 | 黄色网页在线看 | 免费观看一级黄色片 | 国产精品免费久久久久 | 色猫av| 免费在线成人网 | 亚洲国产高清一区 | 欧美成人一区二区视频 | 国产精品爱久久久久久久 | 99精品视频在线 | 婷婷一区二区三区 | 免费国产成人高清在线看软件 | 黄污污网站 | 可以看毛片的网址 | 国产精品中文在线 | 亚洲最大中文字幕 | 国产午夜免费视频 | 欧美日韩在线视频一区二区 | 久久精品国产99国产精品亚洲 | 日韩视频一二三 | 色日本视频 | 黄色片快播 | 最近免费中文字幕在线视频2 | chinesehdxxxx实拍| 亚洲精品在线观看网站 | 亚洲精品日韩色噜噜久久五月 | 久草在线最新 | 91九色丨porny丨国产jk | 麻豆视频在线观看免费网站 | 91综合在线观看 | 天堂成人国产精品一区 | 国产亚洲精品综合一区91555 | 国产激情精品一区二区三区 |