最近在做项目的账号管理这一块儿的功能。每一项账号操作相关的功能,都要涉及到多张表的读写。这个时候自然联想到用数据库的事务进行操作。否则,一处发生异常,将导致脏数据的产生。
ibatis+spring框架下事务的代码写法有两种方式:注解方式和声明事务起始点。
需要的spring的配置文件如下:
- <bean id="transactionManager"
- class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="dataSource"></property>
- </bean>
-
- <tx:annotation-driven transaction-manager="transactionManager" />
-
- <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" >
- <property name="driverClassName" value="${jdbc.driver}"/>
- <property name="url" value="${jdbc.url}"/>
- <property name="username" value="${jdbc.username}"/>
- <property name="password" value="${jdbc.password}"/>
- <property name="maxActive" 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;
- }
个人比较偏好第一种,开发效率高,配置简洁。