MyBatis-整合Spring

1.要点:
1)利用Spring的容器通过单例的方式管理SqlSessionFactory。
2)Spring和MyBatis整合生成代理对象,使用sqlSessionFactory创建SqlSession
3)持久层的mapper需要由Spring进行管理。
2.代码结构
该章节是接续前面的例子继续学习,下面db.properties,log4j.properteis,User.java同前面章节相同,不在重复。需要加入MyBatis,MyBatis-Spring,Spring的jar包,这里lib中的内容省略。后面章节逐步给出其他文件的代码。
├─config
│  │  db.properties //数据库配置文件
│  │  log4j.properties //log输出配置文件
│  │
│  ├─mybatis
│  │      sqlMapConfig.xml
│  │
│  └─spring
│          applicationContext.xml
│
├─lib
│	...
│
├─src
│  ├─mapper
│  │      UserMapper.java
│  │      UserMapper.xml
│  │
│  └─po
│          User.java //用户对象
│
└─test
    └─high
            MapperTest.java
3.applicationContext.xml
配置Spring所需要的东西,可以看出
1)利用Spring的容器通过单例的方式管理SqlSessionFactory。
2)持久层的mapper需要由Spring进行管理。
3)另外,SqlSession由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:mybatis-spring="http://mybatis.org/schema/mybatis-spring"
	xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd
		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
		http://mybatis.org/schema/mybatis-spring http://mybatis.org/schema/mybatis-spring-1.2.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd">

	<context:property-placeholder location="classpath:db.properties"/>
	
	<!-- c3p0连接池配置 -->  
	<bean id="c3p0DataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">  
	     <property name="user" value="${jdbc.username}"/>
	     <property name="password" value="${jdbc.password}"/>
	     <property name="driverClass" value="${jdbc.driver}"/>
	     <property name="jdbcUrl" value="${jdbc.url}"/>
	     <!-- 其他属性都使用默认值 -->
	</bean> 
	
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="configLocation" value="mybatis/sqlMapConfig.xml"></property>
		<property name="dataSource" ref="c3p0DataSource"></property>
	</bean>
	
	<!-- 基本方法:根据Mapper接口生成单个代理对象,如果有多个Mapper需要创建多个Bean,这样比较麻烦 
	<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
		<property name="mapperInterface" value="mapper.UserMapper"/>
		<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
	</bean>
	-->
	
	<!-- 高级方法:指定扫描的包,从该包中扫描对应的mapper接口和xml配置文件,然后自动创建代理对象,并在spring中注入 -->
	<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
		<!-- 配置需要扫描的包,这里不能使用通配符,若多个包,用逗号分开-->
		<property name="basePackage" value="mapper,otherpackage"/>
		<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
	</bean>
</beans>
4.sqlMapConfig.xml
这里配置一些MyBatis特殊的内容,比如别名,setting等。包映射等内容都移到Spring中的配置文件中完成。
<?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>
  <!-- 指定别名包 -->
  <typeAliases>
  	<package name="po"></package>
  </typeAliases>
  
  <!-- 指定需要扫描的映射接口所在的包 -->
  <!-- 由于在Spring的配置文件中配置了MapperScannerConfigurer,此处就不需要再次配置扫描路径了。 
  <mappers>
    <package name="mapper"/>
  </mappers>
  -->
</configuration>
5.UserMapper.xml和 UserMapper.java
跟之前的章节没啥区别。
<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE mapper  
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">  
<mapper namespace="mapper.UserMapper"> 
	<select id="selectUserByName" parameterType="String" resultType="User">
		select * from user where username = #{username};
	</select>
</mapper>  
package mapper;
import java.util.List;

import po.User;

public interface UserMapper {
	List<User> selectUserByName(String username) throws Exception;
}
6.MapperTest.java
package high;

import java.util.List;

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import mapper.UserMapper;
import po.User;

public class MapperTest {
	public static void main(String[] args) throws Exception {
		ApplicationContext ctx = new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml");
		//MapperScannerConfigurer自动扫描UserMapper接口,并将首字母小写的名字注册到Spring中。
		UserMapper userMapper = (UserMapper) ctx.getBean("userMapper");
		
		List<User> list = userMapper.selectUserByName("high");
		System.out.println(list);
	}
}
<完>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值