Spring整合Mybatis

一、引入需要的基础jar包

spring-core-3.2.13.RELEASE.jar
spring-beans-3.2.13.RELEASE.jar
spring-aop-3.2.13.RELEASE.jar
aopalliance-1.0.jar
aspectjweaver-1.6.9.jar
spring-context-3.2.13.RELEASE.jar
spring-expression-3.2.13.RELEASE.jar
spring-jdbc-3.2.13.RELEASE.jar
spring-tx-3.2.13.RELEASE.jar
commons-dbcp-1.4.jar
commons-pool-1.6.jar
log4j-1.2.17.jar
commons-logging-1.1.1.jar
mybatis-3.2.2.jar
mysql-connector-java-5.1.0-bin.jar
mybatis-spring-1.2.0.jar 整合jar

二、准备核心配置文件

原mybatis核心配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
		PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
		"http://mybatis.org/dtd/mybatis-3-config.dtd">

<!--  根节点  整体结构 -->
<configuration>
    <!-- 先引入数据源文件 -->
    <properties resource="database.properties" />
    
    <!-- 设置 -->
    <settings>
       <setting name="logImpl" value="LOG4J"></setting>
       <!--自动映射 默认值为 PARTIAL -->
       <setting name="autoMappingBehavior" value="NONE"/>
    </settings> 
    
    <!-- 配置这个包下所有的类型,别名默认为类名 -->
    <typeAliases>
        <package name="cn.siwen.pojo"/>
    </typeAliases>
    
     <!-- 配置所使用的环境 可多套 必须默认指定某一套。 -->
	<environments default="test">
		<environment id="test">
			<transactionManager type="JDBC" />
			<dataSource type="POOLED">
				<property name="driver" value="${driver}" />
				<property name="url" value="${url}" />
				<property name="username" value="${username}" />
				<property name="password" value="${password}" />
			</dataSource>
		</environment>
	</environments>
	
	 <!-- 需要将mapper文件加入到配置文件中 -->
	<mappers>
		<mapper resource="cn/siwen/dao/mapping/UserMapping.xml" />
	</mappers>
</configuration>

mybatis使用SqlSessionFactory核心工厂类创建SqlSession会话

Spring整合Mybatis:需要使用SqlSessionFactory的子类SqlSessionFactoryBean,将它放入spring容器中

SqlSessionFactoryBean的三个重要属性

  1. dataSource:设置数据源
  2. mapperLocations:设置映射文件地址
  3. configLocation:设置mybatis配置文件位置
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:p="http://www.springframework.org/schema/p"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop"
	xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd
		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd">
    
    <!--加载database.properties配置文件 -->
    <bean id="database" class="org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer">
       <property name="location" value="classpath:database.properties" />
    </bean>
    
    <!-- 创建数据源bean -->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
      <property name="driverClassName" value="${driver}" />
      <property name="url" value="${url}" />
      <property name="username" value="${username}" />
      <property name="password" value="${password}" />
    </bean>
 
    <!-- 创建SqlSessionFactoryBean对象 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> 
      <!-- 设置数据源属性,提取mybatis配置文件的数据源 -->
      <property name="dataSource" ref="dataSource" />
      <!-- 设置映射文件地址 -->
      <property name="mapperLocations" value="classpath:cn/siwen/dao/mapping/*.xml" />
      <!-- 加载mybatis核心配置文件 -->
      <property name="configLocation" value="classpath:mybatis-config.xml" />
    </bean>
</beans>
现Mybatis配置文件

只需要配置一些基础设置

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
		PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
		"http://mybatis.org/dtd/mybatis-3-config.dtd">

<!--  根节点  整体结构 -->
<configuration>
    <!-- 先引入数据源文件 -->
    <properties resource="database.properties" />
    
    <!-- 设置 -->
    <settings>
       <setting name="logImpl" value="LOG4J"></setting>
       <!--自动映射 默认值为 PARTIAL -->
       <setting name="autoMappingBehavior" value="NONE"/>
    </settings> 
    
    <!-- 配置这个包下所有的类型,别名默认为类名 -->
    <typeAliases>
        <package name="cn.siwen.pojo"/>
    </typeAliases>
</configuration>

整合方式一

创建子类继承SqlSessionDaoSupport类并实现mapping映射接口

SqlSessionDaoSupport类中有SqlSession属性与sqlSessionFactory属性

通过关联spring容器中的SqlSessionFactoryBean对象可以得到SqlSession会话工厂

package cn.siwen.dao.impl;

import org.apache.ibatis.session.SqlSession;
import org.mybatis.spring.support.SqlSessionDaoSupport;
import cn.siwen.dao.mapping.UserMapping;
import cn.siwen.pojo.User;

public class UserDaoImpl extends SqlSessionDaoSupport implements UserMapping{

	@Override
	//添加用户
	public int addUser(User user) {
	    //调用父类的getSqlSession()方法得到SqlSession会话工厂
		SqlSession session=getSqlSession();
		UserMapping u=session.getMapper(UserMapping.class);
		return u.addUser(user);
	}
}

在spring配置文件中添加

<bean id="UserDaoImpl" class="cn.siwen.dao.impl.UserDaoImpl">
  <!--属性关联SqlSessionFactoryBean对象-->
  <property name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean>
缺点: 每个映射接口都需要实现

整合方式二

在Spring容器添加MapperFactoryBean的bean对象

MapperFactoryBean类中有mapperInterface属性与sqlSessionFactory属性

mapperInterface属性指定某个映射接口的全类名

sqlSessionFactory属性关联spring容器中的SqlSessionFactoryBean对象

MapperFactoryBean的bean对象相当于映射接口的现实类,得到容器对象可以直接执行映射接口方法,不用在去自己使用SqlSession会话工厂

<!--整合方式二 -->
<bean id="UserDaoImpl" class="org.mybatis.spring.mapper.MapperFactoryBean">
  <!--将容器中的SqlSessionFactoryBean对象注入 -->
  <property name="sqlSessionFactory" ref="sqlSessionFactory" />
  <!--指定映射接口的位置-->
  <property name="mapperInterface" value="cn.siwen.dao.mapping.UserMapping" />
</bean>
缺点:每个映射接口都要添加MapperFactoryBean的bean对象

整合方式三

在Spring容器添加MapperScannerConfigurer的bean对象

MapperScannerConfigurer类中有basePackage属性

basePackage属性指定扫描的映射接口的所在包,批量生产mapper

<!--整合方式三-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  <!-- 指定扫描的包 -->
  <property name="basePackage" value="cn.siwen.dao.mapping" />
</bean>

容器不需要指定idname属性

批量产生mapper(映射接口的现实类)在Spring Ioc中id值默认约定为接口名(接口首字母小写)

例如:<property name=“userdao” ref=“userMapping” />

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值