事务具有四个特征(ACID):
原子性( Atomicity )
指整个数据库事务是不可分割的工作单位。只有使据库中所有的操作执行成功,才算整个事务成功;事务中任何一个SQL语句执行失败,那么已经执行成功的SQL语句也必须撤销,数据库状态应该退回到执行事务前的状态。
一致性( Consistency )
事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是 不一致的状态。
隔离性( Isolation )
一个事务的执行不能与其它事务互相干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
事务锁的概念:数据库管理系统采用锁机制来实现事务的隔离性。当多个事务同时更新数据库中相同的数据时,只允许持有锁的事务能更新该数据,其他事务必须等待,直到前一个事务释放了锁,其他事务才有机会更新该数据。
持续性( Durability )
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
这四个特性简称为 ACID 特性。
事务的操作
Session(会话):表示一个唯一的登陆用户。在Oracle中,每一个登陆到数据库上的用户都会自动的分配一个 Session,即:每一个session都表示不同的用户,而每一个session都有自己独立事务。
每个Session的事务处理操作都可以使用两个命令:
commit:提交事务。只有执行了commit 操作之后,更新操作才真正写入数据库,而没有 commit之前的所有更新操作都会保存在事务事务缓冲区中。
rollback:回退事务。如果发现更新操作有问题,则可以使用 rollback 恢复所有更新操作退回到执行事务前的状态。
事务的隔离性( Isolation )
相同数据被某个session获得,则该数据的执行权被占据,其他的session不能操作。如果有其他session请求操作该数据,则只有等待获得该数据执行权的session提交操作或者回滚操作后。后来的session才能获得该数据的执行权。