在JDBC3.0中(JDK4.0),引入了一个新特性Savepoint。我们知道,在JDBC2.0中的事务支持让开发者可以控制对数据的并发访问,从而保证数据的一致性。但有时候我们需要对事务多一点的控制,而不是在当前的事务中简单地对每一个改变进行回滚。在 JDBC 3.0 下,我们可以通过 Savepoint 获得这种控制。 Savepoint 接口允许您将事务分割为各个逻辑断点,以控制有多少事务需要回滚。下图将说明如何在事务中运用 Savepoint。 JDBC下使用Savepoint
示例代码:
示例结果就是,insert语句将被执行,update语句未执行,其被回滚了。Hibernate下使用Savepoint
示例:
Spring对Savepoint的支持