Spring @Transactional使用的示例
Spring @Transactional使用的示例:
参考:
http://blog.csdn.net/seng3018/article/details/6690527
http://blog.sina.com.cn/s/blog_667ac0360102ebem.html
context.xml:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.springframework.org/schema/beans" xmlns:p="http://www.springframework.org/schema/p" xmlns:util="http://www.springframework.org/schema/util"
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/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.1.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.1.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd">
<bean id="dbcpds" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="oracle.jdbc.OracleDriver"></property>
<property name="url" value="jdbc:oracle:thin:@localhost:1521:ora11"></property>
<property name="username" value="a"></property>
<property name="password" value="b"></property>
<property name="initialSize" value="5"></property>
<property name="maxActive" value="10"></property>
</bean>
<bean id="jdbcSpitter2DAO" class="com.stono.sprjdbc.JdbcSpitter2Dao">
<property name="dataSource" ref="dbcpds"></property>
</bean>
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dbcpds"></property>
</bean>
<tx:annotation-driven transaction-manager="txManager" />
</beans>
POJO:
package com.stono.sprjdbc;
public class SpitterObj {
private String ljdm;
private String ljpym;
public String getLjdm() {
return ljdm;
}
public void setLjdm(String ljdm) {
this.ljdm = ljdm;
}
public String getLjpym() {
return ljpym;
}
public void setLjpym(String ljpym) {
this.ljpym = ljpym;
}
}
DAO:
package com.stono.sprjdbc;
import java.util.Map;
public interface SpitterDAO {
void insertSpitter(SpitterObj obj);
void namedInsertSpitter(Map<String, Object> map);
void updateSpitter(SpitterObj obj);
void deleteSpitter(SpitterObj obj);
SpitterObj getSpitter(String ljdm);
}
DAO Implements:
package com.stono.sprjdbc;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcDaoSupport;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
public class JdbcSpitter2Dao extends NamedParameterJdbcDaoSupport implements SpitterDAO {
private static String INSERT_SQL = "insert into ljzdtemp(ljdm,ljpym) values(?,?)";
private static String GET_SQL = "select * from ljzdtemp where ljdm = ?";
private static String UPDATE_SQL = "update ljzdtemp set ljpym=? where ljdm = ?";
private static String DEL_SQL = "delete ljzdtemp where ljdm = ?";
private static String NAMED_INSERT_SQL = "insert into ljzdtemp(ljdm,ljpym) values(:ljdm,:ljpym)";
@Override
public void insertSpitter(SpitterObj obj) {
getJdbcTemplate().update(INSERT_SQL, obj.getLjdm(), obj.getLjpym());
}
// 如下设置会有异常:Exception in thread "main" org.springframework.transaction.IllegalTransactionStateException: No existing
// transaction found for transaction marked with propagation 'mandatory'
// @Transactional(propagation = Propagation.MANDATORY, readOnly = true, timeout = 1)
// 如下进行设置,含有timeout=1的情况,代码中sleep2秒,会有异常:
// Exception in thread "main" org.springframework.transaction.TransactionTimedOutException: Transaction timed out:
// deadline was Sun Oct 25 08:44:43 CST 2015
// @Transactional(propagation = Propagation.REQUIRED, readOnly = true, timeout = 1)
// try {
// Thread.sleep(2000);
// } catch (Exception e) {
// e.printStackTrace();
// }
// 如下设置,会有异常,并且会导致事务回滚,插入没有成功;
// Exception in thread "main" java.lang.ArithmeticException: / by zero
// @Transactional(propagation = Propagation.REQUIRED, readOnly = false, rollbackFor = Exception.class)
// int i = 0, j = 1;
// int k = 1 / i;
// System.out.println(i + j + k);
// 如下设置,同上面的情况也是一样的;
// @Transactional(propagation = Propagation.REQUIRED, readOnly = false, rollbackFor = ArithmeticException.class)
// 如下设置,没有进行回滚设置,但是还是会回滚,因为有异常了;
// @Transactional(propagation = Propagation.REQUIRED, readOnly = false)
// int i = 0, j = 1;
// int k = 1 / i;
// System.out.println(i + j + k);
// 如下设置,就不会发生回滚事件:
// @Transactional(propagation = Propagation.REQUIRED, noRollbackFor = ArithmeticException.class)
// int i = 0, j = 1;
// int k = 1 / i;
// System.out.println(i + j + k);
@Override
public void namedInsertSpitter(Map<String, Object> map) {
getNamedParameterJdbcTemplate().update(NAMED_INSERT_SQL, map);
}
// 如果想用 Propagation.MANDATORY的方式,就在别的方法中调用这个方法,然后在别的方法中加上 Propagation.REQUIRED
// namedInsertSpitter2(map);
@Transactional(propagation = Propagation.MANDATORY)
public void namedInsertSpitter2(Map<String, Object> map) {
getNamedParameterJdbcTemplate().update(NAMED_INSERT_SQL, map);
}
@Override
public void updateSpitter(SpitterObj obj) {
getJdbcTemplate().update(UPDATE_SQL, "aa", "a");
}
// 这样设置readOnly=true竟然没有效果;
@Transactional(propagation = Propagation.REQUIRED, readOnly = true)
@Override
public void deleteSpitter(SpitterObj obj) {
Map<String, Object> map = new HashMap<String, Object>();
map.put("ljdm", "d");
map.put("ljpym", "d");
getNamedParameterJdbcTemplate().update(NAMED_INSERT_SQL, map);
getJdbcTemplate().update(DEL_SQL, "d");
getNamedParameterJdbcTemplate().update(NAMED_INSERT_SQL, map);
getNamedParameterJdbcTemplate().update(NAMED_INSERT_SQL, map);
}
@Override
public SpitterObj getSpitter(String ljdm) {
return getJdbcTemplate().queryForObject(GET_SQL, new RowMapper<SpitterObj>() {
@Override
public SpitterObj mapRow(ResultSet rs, int rowNum) throws SQLException {
SpitterObj obj = new SpitterObj();
obj.setLjdm(rs.getString(4));
obj.setLjpym(rs.getString(5));
return obj;
}
}, 'a');
}
}
AppBean:
package com.stono.sprjdbc;
import java.util.HashMap;
import java.util.Map;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
public class AppBeans15 {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("appbeans15.xml");
// insert(context);
// insertReadOnly(context);
deleteSpitter(context);
}
@Transactional(propagation = Propagation.MANDATORY)
private static void insert(ApplicationContext context) {
SpitterDAO dao2 = (SpitterDAO) context.getBean("jdbcSpitter2DAO");
Map<String, Object> map = new HashMap<String, Object>();
map.put("ljdm", "d");
map.put("ljpym", "d");
dao2.namedInsertSpitter(map);
}
public static void insertReadOnly(ApplicationContext context) {
SpitterDAO dao2 = (SpitterDAO) context.getBean("jdbcSpitter2DAO");
Map<String, Object> map = new HashMap<String, Object>();
map.put("ljdm", "d");
map.put("ljpym", "d");
dao2.namedInsertSpitter(map);
}
public static void deleteSpitter(ApplicationContext context) {
SpitterDAO dao2 = (SpitterDAO) context.getBean("jdbcSpitter2DAO");
dao2.deleteSpitter(null);
}
}
Spring @Transactional使用的示例的更多相关文章
- Spring @Transactional (一)
		
Spring @Transactional (一) 博客分类: JAVA SpringJPAJDBCUPSQL Spring事务的传播行为 在service类前加上@Transactional,声明 ...
 - 数据库事务中的隔离级别和锁+spring Transactional注解
		
数据库事务中的隔离级别和锁 数据库事务在后端开发中占非常重要的地位,如何确保数据读取的正确性.安全性也是我们需要研究的问题.ACID首先总结一下数据库事务正确执行的四个要素(ACID): 原子性(At ...
 - How does Spring @Transactional Really Work?--转
		
原文地址:http://blog.jhades.org/how-does-spring-transactional-really-work/ In this post we will do a dee ...
 - Spring @Transactional 使用
		
Spring @Transactional是Spring提供的一个声明式事务,对代码的侵入性比较小,只需考虑业务逻辑,不需要把事务和业务搞混在一起. @Transactional 可以注解在inter ...
 - spring原理案例-基本项目搭建 03 创建工程运行测试 spring ioc原理实例示例
		
下面开始项目的搭建 使用 Java EE - Eclipse 新建一 Dynamic Web Project Target Runtime 选 Apache Tomcat 7.0(不要选 Apache ...
 - Java:Spring @Transactional工作原理
		
本文将深入研究Spring的事务管理.主要介绍@Transactional在底层是如何工作的.之后的文章将介绍: propagation(事务传播)和isolation(隔离性)等属性的使用 事务使用 ...
 - spring @Transactional 事务注解
		
@Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.SERIALIZABLE, rollbackFor = ...
 - Spring中的IOC示例
		
Spring中的IOC示例 工程的大概内容是: 一个人在中国时用中国话问候大家,在国外时用英语问候大家. 其中, IHelloMessage是接口,用来定义输出问候信息 public interfac ...
 - [转]数据库事务中的隔离级别和锁+spring Transactional注解
		
数据库事务中的隔离级别和锁 数据库事务在后端开发中占非常重要的地位,如何确保数据读取的正确性.安全性也是我们需要研究的问题.ACID首先总结一下数据库事务正确执行的四个要素(ACID): 原子性(At ...
 
随机推荐
- 安卓图表引擎AChartEngine(四) - 源码示例 嵌入Acitivity中的折线图
			
前面几篇博客中都是调用ChartFactory.get***Intent()方法,本节讲的内容调用ChartFactory.get***View()方法,这个方法调用的结果可以嵌入到任何一个Activ ...
 - PHP中的ORM
			
周末找个时间好好写一写 ORM相关的东西,整理整理. 参考:http://www.cnblogs.com/52fhy/p/5353181.html http://www.cnblogs.com/52f ...
 - scrollView顶部空白
			
在iOS7之后,苹果会自动给导航控制器里面的所有UIScrollView顶部都会添加额外的滚动区域64.
 - Linux iptables 防火墙详解
			
0x00 iptables介绍 linux的包过滤功能,即linux防火墙,它由netfilter 和 iptables 两个组件组成. netfilter 组件也称为内核空间,是内核的一部分,由一些 ...
 - Android Service生命周期 Service里面的onStartCommand()方法详解
			
在Demo上,Start一个Service之后,执行顺序:onCreate - > onStartCommand 然后关闭应用,会重新执行上面两步. 但是把代码拷贝到游戏工程发现,关闭游戏后,只 ...
 - Ibatis collect select用法详解
			
问题:之前接触过Ibatis的使用,在做一对多的时候,一般都是手动去填充,非自动让ibatis去填充数据. 下面就用ibatis的自动填充功能来实现. 关键使用到collection 标签下的sele ...
 - Git 解决同步 No value for key branch.master.merge found in
			
[core] repositoryformatversion = 0 filemode = false logallrefupdates = true [remote "origin&quo ...
 - POJ3169差分约束系统
			
题意:有n头牛,编号为1到n,对于关系好的ml头牛,al和bl之间的距离不大于dl,关系差的md头牛,ad和bd之间的距离不大于dd,求第1头牛和第n头牛之间的距离 分析:这是一道差分约束系统的题目, ...
 - MySQL的char和varchar
			
一.VARCHAR与CHAR字符型数据的差异 在MySQL数据库中,用的最多的字符型数据类型就是Varchar和Char,这两种数据类型虽然都是用来存放字符型数据,但是无论从结构还是从数据的保存方式来 ...
 - UIP源码之ARP过程分析
			
之前我们使用UIP实现了tcp和udp通讯今天来说说UIP的实现流程,当然,这篇文章里面只会涉及tcp和udp,暂时还没办法说DHCP,因为UIP的DHCP实现使用了协程的概念,下一章将协程之后再说D ...