1 事务的定义
数据库事务是由一组 SQL 语句组成的一个逻辑工作单元。您可以把事务看作是一组不可分的 SQL 语句,这些语句作为一个整体永久记录在数据库中或一并撤销。比如在银行帐户之间转移资金:一条 UPDATE 语句将从一个帐户的资金总数中减去一部分,另一条 UPDATE 语句将把资金加到另一个帐户中。减操作和加操作必须永久记录在数据库中,或者必须一并撤销 — 否则将损失资金。这个简单的示例仅使用了两条 UPDATE 语句,但一个更实际的事务可能包含许多 INSERT、UPDATE 和 DELETE 语句。
事务开始: 当第一个DML语句一个事务开始(数据操纵语言:insert、delete、select、update增、删、查、改)
事务结束: 当一个commit和rollback语句被触发
当一个DDL语句执行,(数据定义语言 create、alter、drop、truncate)
当一个DCL语句执行,(数据控制语言 grant、revoke(授权、回收)、set role)
用户退出
机器失效或者崩溃
一个事务结束后,下一个可执行的SQL语句自动开始下一个事务,
一个DDL语句或者一个DCL语句自动提交,并且因此一个事务隐式结束.
2 控制事务
1) commit和rollback语句的优点:
确保数据的一致性
在数据永久改变之前进行预览
分组逻辑相关的操作
2) 控制事务:
commit 结束当前事务,使得所有未决的数据永久改变
savepoint name 在当前事务中标记保存点
rollback 结束当前事务,丢弃所有未决的数据改变
rollback to savepoint name 回滚当前事务到指定的保存点,从而丢弃保存点创建后的任何改变.如果忽略 to savepoint子句,rollback语句回滚整个事务.由于保存点是逻辑的,因此,没有办法列出已经创建的保存点
3) 可以用savepoint语句在当前事务中创建一个标记
用rollback to savepoint 语句回退到哪个标记
例如:
update .........
savepoint update_done;
insert..........
rollback to update_done;
回退到保存点,可以用savepoint语句创建一个标记,它把事务分为较小的部分
rollback to savepoint语句丢弃未决的改变到该标记.如果你用与前面的保存点相同的
名字创建了另一个保存点,哪个早一点时间创建的保存点就被删除了.
select * from testtable t;
update testtable set content ='11pp1' where id = 1;
commit;
savepoint kk;
insert into testtable values(12,'kingking',sysdate);
rollback to kk;
commit;
4) 隐式事务处理
在正常的情况下,一个自动提交发生:
DDL语句被发送
DCL语句被发送
正常退出,没有明确地发送commit或rollback语句
在正常的情况下,一个自动回滚发生:
系统发生异常,或者非正常退出
5) commit或rollback之前的数据状态
事务中所在的每一个数据改变在事务被提交之前都是临时的,在commit或rollback语句发布之前数据的状态:
.数据操纵操作首先影响数据库缓冲区,因此,数据以前的状态可以被恢复.
.当前用户可以查询表观察到数据操纵操作的结果.
.其他用户不能观察到当前所做的数据操纵操作的结果.oracle服务器用读一致性定每个用户看到的数据和上次提交时相同.
.其他用户不能改变受影响的行中的数据.
6) 在commit之后数据的状态
.数据在数据库中被永久地改变.
.数据以前的状态永久地丢失.
.所有用户都可以观察到事务的结果.
.受影响的行的锁定被释放:其他用户可以操纵那么行.
.所有保存点给擦除.
7) rollback后的数据状态
.数据的改变被撤消.
.数据的以前的状态被恢复.
.受影响行的锁定被释放.
8) 语句级rollback
.如果一个语句的执行错误被发现,一个事务的一部分可以用隐式的回退丢弃.如果一个单个的DML语句在一个事务的执行期间失败,它的影响被一个语句级的回退撤消, 但在事务中的以前已经由DML语句完成的改变不能丢弃,它们可以由用户显示地提交或回滚.
.oracle在任何DDL(create,建表)语句之前和之后发布一个隐式的提交.所以即使你的DDL语句执行不成功,你也不能回退前面的语句,因此服务器已经发布提交命令.
.执行commit或rollback语句来明确地结束事务.
.oracle服务器在数据上实现锁以防止对数据库中数据的并发操作, 当一个DML语句成功执行时,数据库上的隐式锁被获得,默认情况下,oracle服务器在尽可能的最低级别锁定数据执行带for update子句的lock table语句或select语句可以手动获得数据库上的锁.
3 读一致性
1)数据库用户用两种方法访问数据库:
读操作(select 语句)
写操作(插入,更新,删除语句)
2)你需要读一致性,所以有下面事发生:
数据库读者和写者被确保对数据观察的一致性.
读者不能观察正在变化过程中的数据.
写者被确保对数据库的改变以一致的方式进行.
一个写者所做的改变不破坏另一个写者所做的改变或与其冲突.
3) 读一致性的目的是确保每个用户看到的数据和他最后一次提交,并且在一个DML操作操作开始之前的数据一样.
读一致性是一种自动的执行,该操作在回退段保持一个数据库的局部的拷贝.对数据库进行一个插入,更新或者删除时,oracle服务器在数据改变之前获得相关数据的拷贝,并且将这些数据写到一个回退段(undo segment).所有读数据者,除了发布修改命令的用户,看到的数据还是改变之前的状态;他们看到数据是回退段数据快照.在改变被提交到数据库之前,只有正在修改数的用户能看见数据库的改变,除了他之外的任何人看到都是回退段的快照,这样就确保数据的读者读到一致的数据, 而不是当前正在被修改的数据.
4) 当一个DML语句被提交的时,对数据库所做的改变对任何执行select语句的人成为可见的.在回退段的文件中被旧数据占用的空间被释放以重新使用.
4 锁定:
1) 锁是防止访问相同资源的事务之间的破坏性交互机制.即可以是用户对象(如表或行),也可以是对用户不可见的系统对象(例如共享数据结构和数据字典).
2) oracle数据库怎么锁定数据
oracle锁被自动执行,并且不要求用户干预.对于SQL语句隐式锁是必须的,依赖被请求的动作.隐式锁定除了select外,对所有的SQL都发生.当执行数据操纵语言(DML,insert)操作时,oracle服务器通过DML所防止数据被同时操纵.
用户也可以手动锁定数据,这叫显示锁定.
3) 隐式锁定:
2种锁的模式:
独占锁:不允许其他用户访问
共享锁:允许其他用户访问
高级数据并发操作:
DML:表共享,行独占
查询:不需要锁
DDL:保护对象定义
共享锁是在表级在DML操作期间自动获得的.用这个模式,几个事务可以在相同的资源上获得共享锁.
对于用DML语句修改的每一行,独占锁被自动获得.独占锁在本事务被提交或回滚之前防止行被其他事物修改.该锁确保无其他用户能够在相同的时间修改相同的行,并且覆盖另一个还没有提交的改变.当你修改数据库对象时,DDL锁发生.