您的位置:首页 > 编程语言 > Java开发

spring 事务管理(编程式)

2013-11-22 16:43 387 查看
spring事务管理(编程式)

1、关键抽象类:

Java代码

package org.springframework.transaction;
public interface PlatformTransactionManager {
TransactionStatus getTransaction(TransactionDefinition definition) throws TransactionException;
void commit(TransactionStatus status) throws TransactionException;
void rollback(TransactionStatus status) throws TransactionException;
}


TransactionDefinition定义了事务的隔离成都,传播行为,超时,只读等属性,TransactionStatus代表了一个新的事务发起或者已经存在的事务,可以通过它来控制事务的执行和调查的状态。

Java代码

package org.springframework.transaction;
public interface TransactionStatus extends SavepointManager {

boolean isNewTransaction();

boolean hasSavepoint();

void setRollbackOnly();

boolean isRollbackOnly();

boolean isCompleted();

}


spring提供编程式事务管理和声明式事务管理。

编程式事务管理可以实现细粒度的事务管理。spring提供两种方式,一种为PlatformTransactionManager,另一种为TransactionTemplate。
先使用PlatformTransactionManager实现。

Java代码

package cn.com.gan.spring.database;

public interface IUserDao {
public void insert(User user);
public User find(String name);
}


Java代码

package cn.com.gan.spring.database;

import java.util.List;
import java.util.Map;

import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.TransactionStatus;
import org.springframework.transaction.support.DefaultTransactionDefinition;

import javax.sql.DataSource;

public class UserDao implements IUserDao {
// private DataSource dataSource;
private JdbcTemplate jdbcTemplate;
private PlatformTransactionManager tm;
private DefaultTransactionDefinition df;
public void setDataSource(DataSource dataSource) {
jdbcTemplate = new JdbcTemplate(dataSource);
tm=new DataSourceTransactionManager(dataSource);
df=new DefaultTransactionDefinition();
df.setPropagationBehavior(DefaultTransactionDefinition.PROPAGATION_REQUIRED);
}
@Override
public User find(String name) {
List<Map> list = jdbcTemplate
.queryForList("select * from user where name='" + name + "'");
User user = null;
for (Map map : list) {
user = new User();
user.setName(map.get("name").toString());
user.setAge(Short.parseShort(map.get("age").toString()));
}
return user;
}
@Override
public void insert(User user) {
TransactionStatus ts=tm.getTransaction(df);
try{
jdbcTemplate.update("insert into user(name,age) values(?,?)",
new Object[] { user.getName(), user.getAge() });
jdbcTemplate.update("insert into user(name,age) values(?,?)",
new Object[] { user.getName(), user.getAge() });
}catch(DataAccessException e){
tm.rollback(ts);
e.printStackTrace();
}
tm.commit(ts);
}
}


其中insert为事务管理,如果其中一条插入失败就回滚。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: