MyBatis与Spring的整合
MyBatis与Spring的整合
帅得拖网速 发表于1年前
MyBatis与Spring的整合
  • 发表于 1年前
  • 阅读 75
  • 收藏 2
  • 点赞 0
  • 评论 0

腾讯云 十分钟定制你的第一个小程序>>>   

摘要: MyBatis与Spring的整合

MyBatis与Spring的整合第一步当然是导入各自依赖的Jar包,这里强调一下要导入MyBatis提供的与Spring整合的插件包,

如果用Maven项目的话在pom.xml文件中加入以下依赖便可:

        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>1.3.0</version>
        </dependency>

整合的目的就是将MyBatis的所依赖的连接池,SqlSessiond的创建以及MyBatis的事务管理交给Spring去管理。

以下就是Spring的applicationContext.xml配置文件的内容:

<?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:aop = "http://www.springframework.org/schema/aop"
        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/aop
			http://www.springframework.org/schema/aop/spring-aop.xsd
			http://www.springframework.org/schema/tx
			http://www.springframework.org/schema/tx/spring-tx.xsd">
    <!-- 开启Spring注解功能 -->
    <context:annotation-config />
    <!-- 配置Spring注解扫描 -->
    <context:component-scan base-package = "
							at.flying.dao,
							at.flying.service
							" />

    <!-- 开启AspectJ 注解自动代理机制-->
    <aop:aspectj-autoproxy />
    <!-- 开启事务注解 -->
    <tx:annotation-driven />

    <!--引入外部属性文件-->
    <context:property-placeholder location = "classpath:db.properties" />
    <!--配置C3P0连接池-->
    <bean id = "comboPooledDataSource" class = "com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name = "driverClass" value = "${mysql.driver}" />
        <property name = "jdbcUrl" value = "${mysql.url}" />
        <property name = "user" value = "${mysql.username}" />
        <property name = "password" value = "${mysql.password}" />
    </bean>
    <!--配置SQLSessionFactory工厂-->
    <bean id = "sqlSessionFactory" class = "org.mybatis.spring.SqlSessionFactoryBean">
        <property name = "dataSource" ref = "comboPooledDataSource" />
        <property name = "configLocation" value = "classpath:mybatis.xml" />
    </bean>

    <!--配置事务管理器-->
    <bean id = "transactionManager"
          class = "org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name = "dataSource" ref = "comboPooledDataSource" />
    </bean>
</beans>

我事务管理采用的是注解的方式,所以这里有必要强调一下,

如果事务管理采用注解的方式的话,那么在配置事务管理器的时候Bean的id必须指定为 transactionManager,否则报错。

如下图所示:

然后就是MyBatis的配置文件和映射文件,比较简单就不再阐述。

然后就是在写DAO层的时候,自己的DAO类可以(并非必须)继承 org.mybatis.spring.support.SqlSessionDaoSupport 这个类。

这类似于使用Hibernate时继承HibernateDaoSupport一样。

如下图所示:

共有 人打赏支持
粉丝 4
博文 50
码字总数 43453
×
帅得拖网速
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: