最近在做项目的账号管理这一块儿的功能。每一项账号操作相关的功能,都要涉及到多张表的读写。这个时候自然联想到用数据库的事务进行操作。否则,一处发生异常,将导致脏数据的产生。
ibatis+spring框架下事务的代码写法有两种方式:注解方式和声明事务起始点。
需要的spring的配置文件如下:
<bean
>
<property ref="dataSource"></property>
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />
<bean >
<property value="${jdbc.driver}"/>
<property value="${jdbc.url}"/>
<property value="${jdbc.username}"/>
<property value="${jdbc.password}"/>
<property value="${jdbc.maxActive}"/>
</bean>
一.注解方式:
在类或方法上面加@Transactional(isolation = Isolation.SERIALIZABLE),序列化这个级别在事务隔离级别里面是最高的。考虑到账号操作比较重要,就选了这个级别。
二.Java代码声明事务起始点
@Override
public boolean deleteAdminGroup(Integer id) {
DefaultTransactionDefinition definition = new DefaultTransactionDefinition();
definition.setIsolationLevel(DefaultTransactionDefinition.ISOLATION_SERIALIZABLE);
TransactionStatus status = transactionManager.getTransaction(definition);//事务开始
List<JdOrg> childGroupList = new ArrayList<JdOrg>();
try {
......
transactionManager.commit(status);//提交事务
} catch (Exception e) {
LOG.error(e.getMessage(), e);
transactionManager.rollback(status);//事务回滚
return false;
}
return true;
}
个人比较偏好第一种,开发效率高,配置简洁。
Spring 的详细介绍:请点这里
Spring 的下载地址:请点这里
相关阅读:
基于 Spring 设计并实现 RESTful Web Services
Spring-3.2.4 + Quartz-2.2.0集成实例
Spring 3.x 企业应用开发实战 PDF完整高清扫描版+源代码