基於SSM框架的web入門項目(五)學習記錄

配合嗶哩嗶哩視頻學習【SSM 框架】SpringMVC+Spring+Mybatis SSM 整合+實戰+源碼13集

5.MyBatis整合Spring-整合JDBC事務

5.1.修改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">
	
	<!-- 讀取jdbc.properties -->
	<context:property-placeholder location="classpath:jdbc.properties"/>
	
	<!-- 創建DataSource -->
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
		<property name="url" value="${jdbc.url}"/>
		<property name="driverClassName" value="${jdbc.driverClass}"/>
		<property name="username" value="${jdbc.user}"/>
		<property name="password" value="${jdbc.password}"/>
		<property name="maxActive" value="10"/>
		<property name="maxIdle" value="5"/>
	</bean>	
	
	<!-- 創建SqlSessionFactory對象 -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<!-- 關聯連接池 -->
		<property name="dataSource" ref="dataSource"/>
		<!-- 加載sql映射文件 -->
		<property name="mapperLocations" value="classpath:mapper/*.xml"/>
	</bean>
	
	<!-- 配置Mapper接口掃描 -->	
	<!-- 
		注意:如果使用Mapper接口包掃描,那麼每個maopper接口在spring容器中的id名稱爲類名:例如CustomerMapper->customerMapper
	 -->
	<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
		<!-- 配置mapper接口所在包的路徑 -->
		<property name="basePackage" value="com.ssmlcx.dao"/>
	</bean>
	
	<!-- 開啓spring的IOC註解掃描 -->
	<context:component-scan base-package="com.ssm"></context:component-scan>
	
	
	<!-- 開啓spring的事務管理 -->
	<!-- 事務管理器 -->
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dataSource"/>
	</bean>
	
	<!-- 啓用spring事務註解 -->
	<tx:annotation-driven transaction-manager="transactionManager"/>
</beans>

5.2.在業務方法上添加註釋

package com.ssm.service.impl;

import javax.annotation.Resource;

import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import com.ssm.dao.CustomerMapper;
import com.ssm.domain.Customer;
import com.ssm.service.CustomerService;

@Service("customerServiceImpl")
@Transactional
public class CustomerServiceImpl implements CustomerService {
	//注入mapper對象
	@Resource
	private CustomerMapper customerMapper;
	
	
	public void saveCustomer(Customer customer) {
		customerMapper.saveCustomer(customer);
		
		//模擬異常
		int i = 100/0;
		customerMapper.saveCustomer(customer);
		
	}

}

5…測試類

package com.ssm.test;

import java.io.IOException;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.ssm.dao.CustomerMapper;
import com.ssm.domain.Customer;
import com.ssm.service.CustomerService;



public class MyBatisSpringTest {
	@org.junit.Test
	public void Test() throws IOException
	{
		//1.加載spring配置
		
		ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
		
		CustomerService customerService = (CustomerService)ac.getBean("customerServiceImpl");
		
		CustomerMapper customerMapper = (CustomerMapper)ac.getBean("customerMapper");
		
		//3.調用父類方法
		Customer customer = new Customer();
		customer.setName("老李6666");
		customer.setGender("男");
		customer.setTelephone("020-77777");
		customer.setAddress("清華紫光");
		customerService.saveCustomer(customer);
	}
}

結果:

數據庫中無數據加入,事務發生回滾

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章