最近在做项目的账号管理这一块儿的功能。每一项账号操作相关的功能,都要涉及到多张表的读写。这个时候自然联想到用数据库的事务进行操作。否则,一处发生异常,将导致脏数据的产生。
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; }个人比较偏好第一种,开发效率高,配置简洁。