日期:2014-05-16  浏览次数:20396 次

spring+ibatis框架下事务代码的编写示例

    最近在做项目的账号管理这一块儿的功能。每一项账号操作相关的功能,都要涉及到多张表的读写。这个时候自然联想到用数据库的事务进行操作。否则,一处发生异常,将导致脏数据的产生。

    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;
	}
    个人比较偏好第一种,开发效率高,配置简洁。