Hibernate 事务和并发控制
++YONG 原创,转载请注明
1. 事务介绍:
1.1. 事务的定义:
事务就是指作为单个逻辑工作单元执行的一组数据操作,这些操作要么必须全部成功,要么必须全
部失败,以保证数据的一致性和完整性。
1.2. 事务具有 ACID 属性:
o原子性(Atomic):事务由一个或多个行为绑在一起组成,好像是一个单独的工作单元。原子性确保在事务
中的所有操作要么都发生,要么都不发生。
o一致性(Consistent):一旦一个事务结束了(不管成功与否),系统所处的状态和它的业务规则是一致的。即
数据应当不会被破坏。
o隔离性(Isolated):事务应该允许多个用户操作同一个数据,一个用户的操作不会和其他用户的操作相混淆。
o持久性(Durable):一旦事务完成,事务的结果应该持久化。
事务的 ACID 特性是由关系数据库管理系统(RDBMS)来实现的。
o数据库管理系统采用日志来保证事务的原子性、一致性和持久性。日志记录了事务对数据库所做的更新,如
果某个事务在执行过程中发生错误,就可以根据日志,撤销事务对数据库已做的更新,使数据库退回到执
行事务前的初始状态。
o数据库管理系统采用锁机制来实现事务的隔离性。当多个事务同时更新数据库相同的数据时,只允许持有锁
的事务能更新该数据,其他事务必须等待,直到前一个事务释放了锁,其他事务才有机会更新该数据。
2. 数据库事务声明:
数据库系统的客户程序只要向数据库系统声明了一个事务,数据库系统就会自动保证事务的 ACID
特性。在 JDBC API 中,java.sql.Connection 类代表一个数据库连接。它提供了以下方法控制事务:
1. setAutoCommit(Boolean autoCommit):设置是否自动提交事务。
2. commit():提交事务。
3. rollback():撤销事务。
2.1. JDBC API 声明事务的示例代码如下:
Connection = null;