oracle core读书笔记2transactions and consistency

本文详细介绍了数据库中事务启动和结束的过程,包括选取回滚段、更新事务表状态以及生成重做日志等内容。当会话开始事务时,它会选择一个回滚段,并从事务表中选择一个条目,增加包裹号,更改状态为“活动”。同时,这些改变会生成重做变更向量并最终写入重做日志文件。当事务完成时,会话会将状态设置回“空闲”,并在事务表项中记录当前SCN。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Start and End of Transaction
When a session starts a transaction, it picks an undo segment, picks an entry from the transaction table,
increments the wrap#, changes the state to “active” (value 10), and modifies a few other columns. Since
this is a change to a database block, it will generate a redo change vector (with an OP code of 5.2) that will
ultimately get into the redo log file; this declares to the world and writes into the database the fact that
the session has an active transaction.
Similarly, when the transaction completes (typically through a commit; call), the session sets the
state back to “free” (value 9) and updates a few other columns in the entry—in particular, by writing the
current SCN into the scn column. Again, this constitutes a change to the database so it generates a redo
change vector (with an OP code of 5.4) that will go into the redo log. This moment is also rather special
because (historically) this is the “moment” when your session protects its committed changes by issuing
a call to the log writer (lgwr) to write the current content of the redo log buffer to disc and then waiting
for the log writer to confirm that it has finished writing. Once the log writer has written, you have a
permanent record of the transaction—in the ACID jargon, the transaction is now durable.

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/263455/viewspace-751265/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/263455/viewspace-751265/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值