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

spring事务管理 数据库事务的4个特性

spring学习笔记:spring事务管理

数据库事务的4个特性:

?


??? 一致性(consistency):事务操作之后,数据库所处的状态和业务规则是一致的;比如a,b账户相互转账之后,总金额不变;


??? 隔离性(isolation):操作中的事务不相互影响;


??? 持久性(durability):事务提交后被持久化到数据库.


? 数据并发产生的问题:


??? 脏读:一个事物a读到了另一个事务b未提交的数据,则b回滚后,a读取的数据无效;


??? 不可重复读:一个事物a第二次读到了另一个事务b修改的数据;


??? 幻读:在统计数据的事务a两次统计的数据不一致(因为有其他事务新增数据)


??? 第一类丢失更新:a事务回滚覆盖了b事务提交的数据;


??? 第二类丢失更新:a事务覆盖了b事务提交的数据.


??? 事物隔离级别: READ_UNCOMMITED, READ_COMMITED, REPEATABLE_READ, SERIALIZABLE; 一般情况下READ_COMMITED足够了.


spring事务管理相关的接口:


??? TransactionDefinition:代表一个事物,描述了事务的隔离级别, 超时时间,事务是否只读, 传播规则等等;


??? TransactionStatus:描述事物的状态;


??? PlatformTransactionManager:事务管理器接口, 只定义了3个方法:getTransaction()获取事务的状态; commit();rollback();


??? 事务管理器的实现类有多种,根据具体的持久层框架的不同而不同;


spring中的事务传播行为的种类:


??? PROPAGATION_SUPPORTS: 如果已经存在事务,则加入事务;如果没有事务,则以非事务的方式执行;


??? PROPAGATION_MANDATORY: 使用当前事务, 如果没有, 则抛出异常;


??? PROPAGATION_REQUIRED_NEW: 新建事务,如果当前有事务, 则挂起;

??? PROPAGATION_NOT_SUPPORTED:以非事务的方式执行, 如果当前有事务, 则挂起;


??? PROPAGATION_NEVER:以非事务的方式执行, 如果当前有事务,则抛出异常;


使用spring声明式的事务管理:


??? 1 把dao,service注入到spring容器(这些dao, service不涉及事务);


??? 2 需要注入一个transactionManager(它需要dataSource);

??? 3 通过TransactionProxyFactoryBean为目标对象(需要事务的dao, service等等)提供事务增强,产生增强后的代理对象.


看代码:先添加一个CompanyService,

  1. package?services;??? ??
  2. import?java.util.List;??? ??
  3. import?model.Company;??? ??
  4. import?dao.hibernate.CompanyDao;??? ??
  5. ?? ??
  6. public?class?CompanyService?{??? ??
  7. ?private?CompanyDao?companyDao;??? ??
  8. ?public?CompanyDao?getCompanyDao()?{??? ??
  9. ??return?companyDao;??? ??
  10. ?}??? ??
  11. ?public?void?setCompanyDao(CompanyDao?companyDao)?{??? ??
  12. ??this.companyDao?=?companyDao;??? ??
  13. ?}??? ??
  14. ?public?void?insertCompany(Company?c){??? ??
  15. ??//some?security?check??? ??
  16. ??companyDao.save(c);??? ??
  17. ??//some?updates??? ??
  18. ?}??? ??
  19. ?public?void?deleteCompany(int?id){??? ??
  20. ??//some?security?check??? ??
  21. ??companyDao.deleteById(id);??? ??
  22. ??//?some?updates??? ??
  23. ?}??? ??
  24. ?public