最近在做項目的賬號管理這一塊兒的功能。每一項賬號操作相關的功能,都要涉及到多張表的讀寫。這個時候自然聯想到用數據庫的事務進行操作。否則,一處發生異常,將導致髒數據的產生。
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;
}
個人比較偏好第一種,開發效率高,配置簡潔。
Spring 的詳細介紹:請點這裡
Spring 的下載地址:請點這裡