1.什么是事务:
访问并可能更新数据库中各种数据项的一个程序执行单元(unit)
一组逻辑操作单元,使数据从一种状态变换到另一种状态。
一组逻辑操作单元:一个或多个DML操作。
2.事务的四大特性:
- 原子性
事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做
- 一致性
事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是 不一致的状态。
- 隔离性
一个事务的执行不能其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
- 持续性
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
3.事务处理的原则:
- 保证所事务都作为一个工作单元来执行,即使出现了故障,都不能改变这种执行方式。
- 当在一个事务中执行多个操作时,要么所有的事务都被提交(commit),那么这些修改就永久地保存下来;要么数据库管理系统将放弃所作的所有修改,整个事务回滚(rollback)到最初状态。
4.重要说明
- 数据一旦提交,就不可回滚
- 有一些操作会自动提交,提交后不可回滚
5.有哪些操作会自动提交?如何解决?
- DDL操作一旦执行,都会自动提交。
set autocommit = false 对DDL操作失效
- DML默认情况下,一旦执行,就会自动提交。
通过set autocommit = false的方式取消DML操作的自动提交。
- 默认在关闭连接时,会自动的提交数据
连接在事务单元的后面关闭