Spring框架

8.2.3 Spring提供的事务管理器

         Spring从不同的事务管理API中抽象出了一整套事务管理机制,让事务管理代码从特定的事务技术中独立出来。开发人员通过配置的方式进行事务管理,而不必了解其底层是如何实现的。

         Spring的核心事务管理抽象是PlatformTransactionManager。它为事务管理封装了一组独立于技术的方法。无论使用Spring的哪种事务管理策略(编程式或声明式),事务管理器都是必须的。

         事务管理器可以以普通的bean的形式声明在Spring IOC容器中。

8.2.4事务管理器的主要实现

  • DataSourceTransactionManager:在应用程序中只需要处理一个数据源,而且通过JDBC存取。
  • JtaTransactionManager:在JavaEE应用服务器上用JTA(Java Transaction API)进行事务管理
  • HibernateTransactionManager:用Hibernate框架存取数据库

8.3 测试数据准备

8.3.1 需求

8.3.2 数据库表

CREATE TABLE book (

  isbn VARCHAR (50) PRIMARY KEY,

  book_name VARCHAR (100),

  price INT

) ;

 

CREATE TABLE book_stock (

  isbn VARCHAR (50) PRIMARY KEY,

  stock INT,

  CHECK (stock > 0)

) ;

 

CREATE TABLE account (

  username VARCHAR (50) PRIMARY KEY,

  balance INT,

  CHECK (balance > 0)

) ;

 

INSERT INTO account (`username`,`balance`) VALUES ('Tom',100000);

INSERT INTO account (`username`,`balance`) VALUES ('Jerry',150000);

 

INSERT INTO book (`isbn`,`book_name`,`price`) VALUES ('ISBN-001','book01',100);

INSERT INTO book (`isbn`,`book_name`,`price`) VALUES ('ISBN-002','book02',200);

INSERT INTO book (`isbn`,`book_name`,`price`) VALUES ('ISBN-003','book03',300);

INSERT INTO book (`isbn`,`book_name`,`price`) VALUES ('ISBN-004','book04',400);

INSERT INTO book (`isbn`,`book_name`,`price`) VALUES ('ISBN-005','book05',500);

 

INSERT INTO book_stock (`isbn`,`stock`) VALUES ('ISBN-001',1000);

INSERT INTO book_stock (`isbn`,`stock`) VALUES ('ISBN-002',2000);

INSERT INTO book_stock (`isbn`,`stock`) VALUES ('ISBN-003',3000);

INSERT INTO book_stock (`isbn`,`stock`) VALUES ('ISBN-004',4000);

INSERT INTO book_stock (`isbn`,`stock`) VALUES ('ISBN-005',5000);