[size=large]提到事务管理,首先想到的是事务回滚和事务提交。
那么到底什么是事务,为什么要进行事务管理呢?
首先,事务就是对一系列的数据库操作(比如插入多条数据)进行统一的提交或回滚操作,如果插入成功,那么一起成功,如果中间有一条出现异常,那么回滚之前的所有操作。也就是说事务可实现“要么完全成功,要不全部不成功”,保证数据的完整性和一致性,使我们在开发中能方便地实现一些业务逻辑。比如,在股票交易时,除了记录交易的过程,还要更新交易完成之后的账户状态。这两个操作显然必须“要么完全成功,要么全部不成功”,否则,你的麻烦就大了。
这样可以防止出现脏数据,防止数据库数据出现问题。
开发中为了避免这种情况一般都会进行事务管理。
在JDBC中是通过Connection对象进行事务管理的,默认是自动提交事务,可以手工将自动提交关闭,通过commit方法进行提交,rollback方法进行回滚,如果不提交,则数据不会真正的插入到数据库中。
Spring中也有自己的事务管理机制,一般是使用TransactionMananger进行管理,可以通过Spring的注入来完成此功能。
Spring事务管理有两种方式:编程式、声明式。
Spring事务管理的属性有:事务隔离程度、事务传播、事务超时、只读状态
事务隔离程度(isolation level),可以解决数据读取脏数据,不可重复读,幻想读等问题。
事务传播( PROPAGATION):TransactionDefinition 接口中定义了七个事务传播行为
具体可以参考http://struts2.group.iteye.com/group/topic/3642
[/size]
那么到底什么是事务,为什么要进行事务管理呢?
首先,事务就是对一系列的数据库操作(比如插入多条数据)进行统一的提交或回滚操作,如果插入成功,那么一起成功,如果中间有一条出现异常,那么回滚之前的所有操作。也就是说事务可实现“要么完全成功,要不全部不成功”,保证数据的完整性和一致性,使我们在开发中能方便地实现一些业务逻辑。比如,在股票交易时,除了记录交易的过程,还要更新交易完成之后的账户状态。这两个操作显然必须“要么完全成功,要么全部不成功”,否则,你的麻烦就大了。
这样可以防止出现脏数据,防止数据库数据出现问题。
开发中为了避免这种情况一般都会进行事务管理。
在JDBC中是通过Connection对象进行事务管理的,默认是自动提交事务,可以手工将自动提交关闭,通过commit方法进行提交,rollback方法进行回滚,如果不提交,则数据不会真正的插入到数据库中。
Spring中也有自己的事务管理机制,一般是使用TransactionMananger进行管理,可以通过Spring的注入来完成此功能。
Spring事务管理有两种方式:编程式、声明式。
Spring事务管理的属性有:事务隔离程度、事务传播、事务超时、只读状态
事务隔离程度(isolation level),可以解决数据读取脏数据,不可重复读,幻想读等问题。
事务传播( PROPAGATION):TransactionDefinition 接口中定义了七个事务传播行为
具体可以参考http://struts2.group.iteye.com/group/topic/3642
[/size]