spring+mybatis

Posted m97i

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了spring+mybatis相关的知识,希望对你有一定的参考价值。

 

applicationContext-mybatis.xml 配置文件(spring,mybatis集成的配置文件)

<?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-3.1.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context-3.1.xsd
           http://www.springframework.org/schema/tx
           http://www.springframework.org/schema/tx/spring-tx-3.1.xsd
           http://www.springframework.org/schema/aop
           http://www.springframework.org/schema/aop/spring-aop-3.1.xsd">


	<!-- 读取配置文件  两种方法 
	<context:property-placeholder location="classpath:jdbc.properties" />-->
	<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">    
	    <property name="locations">    
	        <list>    
	            <value>classpath*:jdbc.properties</value>    
	        </list>    
	    </property>    
	</bean> 
	
	<!--  配置数据源的两种方法 JNDI获取数据源(DBCP连接池) 
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" scope="singleton">
		<property name="driverClassName" value="${driver}"></property>
		<property name="url" value="${url}"></property>
		<property name="username" value="${username}"></property>
		<property name="password" value="${password}"></property>
		
	</bean>-->
	
	<bean id="dataSource" destroy-method="close"
		class="com.mchange.v2.c3p0.ComboPooledDataSource">
		<property name="driverClass" value="${driver}"/>
		<property name="jdbcUrl" value="${url}?useUnicode=true&characterEncoding=utf8"/>
		<property name="user" value="${username}"/>
		<property name="password" value="${password}"/>
		
	</bean>
	
	  
	<!-- 事务管理 -->
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dataSource"></property>
	</bean>

	<!-- 配置 MyBatis sqlSessionFactory -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource"></property>
		<property name="configLocation" value="classpath:mybatis-config.xml"></property>
		<property name="mapperLocations" value="classpath:dao/*.xml"></property>
	</bean>
	
	<!-- 配置sqlSessionTemplate模板-->
	<bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
		<!-- 构造器进行注入 -->
		<constructor-arg name="sqlSessionFactory" ref="sqlSessionFactory"></constructor-arg>
		
	</bean>
	
	<!-- 把sqlSessionTemplate模板 注入到测试类 -->
	<bean id="empDaoTest" class="test.empTest">
		<property name="sqlSessionTemplate" ref="sqlSessionTemplate"></property>
	</bean>
	




           
</beans>

  

jdbc.propertis配置文件

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/testdb
username=root
password=123

  

mybatis-config.xml配置文件(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>
      <!-- 别名 以后pojo包下的实体类 可以用类名 不用完全限定名了 --> <typeAliases> <package name="pojo"/> </typeAliases> </configuration>

  

 

junit测试类

public class empTest {
	private Logger logger=Logger.getLogger(this.getClass());
	private SqlSessionTemplate sqlSessionTemplate;
	protected ApplicationContext applicationContext=null;
	private empTest test;
	
	@Before
	public void setuo(){
		applicationContext=new ClassPathXmlApplicationContext("applicationContext-mybatis.xml");
		test=(empTest) applicationContext.getBean("empDaoTest");
	}
	
	@Test
	public void tests(){
		
		
		List<Employee> emps=test.sqlSessionTemplate.selectList("dao.EmployeeMapper.getEmployeeList");
		for(Employee emp:emps){
			logger.debug(emp.getName());
		}
		logger.debug(emps.size());
		
	}

  

 

 

 

第一种配置用的是 SqlSessionTemplate模版 

第二种配置用的是 MapperFactoryBean

======================第二种配置方法========================

 

applicationContext-mybatis.xml 配置文件(spring,mybatis集成的配置文件)

<?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-3.1.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context-3.1.xsd
           http://www.springframework.org/schema/tx
           http://www.springframework.org/schema/tx/spring-tx-3.1.xsd
           http://www.springframework.org/schema/aop
           http://www.springframework.org/schema/aop/spring-aop-3.1.xsd">


	<!-- 读取配置文件  两种方法 
	<context:property-placeholder location="classpath:jdbc.properties" />-->
	<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">    
	    <property name="locations">    
	        <list>    
	            <value>classpath*:jdbc.properties</value>    
	        </list>    
	    </property>    
	</bean> 
	
	<!--  配置数据源的两种方法 JNDI获取数据源(DBCP连接池) 
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" scope="singleton">
		<property name="driverClassName" value="${driver}"></property>
		<property name="url" value="${url}"></property>
		<property name="username" value="${username}"></property>
		<property name="password" value="${password}"></property>
		
	</bean>-->
	
	<bean id="dataSource" destroy-method="close"
		class="com.mchange.v2.c3p0.ComboPooledDataSource">
		<property name="driverClass" value="${driver}"/>
		<property name="jdbcUrl" value="${url}?useUnicode=true&characterEncoding=utf8"/>
		<property name="user" value="${username}"/>
		<property name="password" value="${password}"/>
		
	</bean>
	
	  
	<!-- 事务管理 -->
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dataSource"></property>
	</bean>


	<!-- 配置 MyBatis sqlSessionFactory -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource"></property>
		<property name="configLocation" value="classpath:mybatis-config.xml"></property>
	</bean>
	
	<bean id="employeeMapperFactory"  class="org.mybatis.spring.mapper.MapperFactoryBean">
		<property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
		<property name="mapperInterface" value="dao.EmployeeMapper"></property>
	</bean> 
	
	<bean id="employeeServiceImpl" class="service.EmployeeServiceImpl">
		<property name="employeeMapper" ref="employeeMapperFactory"></property>
	</bean>
	

           
</beans>

  

其他配置文件不变

junit测试类

 

public class empTest {
	private Logger logger=Logger.getLogger(this.getClass());
	protected ApplicationContext applicationContext=null;
	private EmployeeServiceImpl employeeServiceImpl;
	@Before
	public void setuo(){
		applicationContext=new ClassPathXmlApplicationContext("applicationContext-mybatis.xml");
		 employeeServiceImpl=(EmployeeServiceImpl) applicationContext.getBean("employeeServiceImpl");
	}
	
	@Test
	public void tests(){
		
		Department department=new Department();
		department.setId(2);
		List<Employee> emplist=employeeServiceImpl.getEmployeelistByDeptId(department);
		for(Employee emp:emplist){
			logger.debug(emp.getName());
			
		}
		
	}

  

 


以上是关于spring+mybatis的主要内容,如果未能解决你的问题,请参考以下文章

Mybatis--02

markdown [mybatis参考]关于mybatis #mybatis的一些片段

Mybatis学习--spring和Mybatis整合

请教mybatis+spring+atomikos的整合问题

mybatis学习(39):动态sql片段

7.Spring:整合Mybatis