首頁 > 資料庫 > mysql教程 > Oracle更新一条数据然后提交的整个经过(包括undo,redo,后台进程

Oracle更新一条数据然后提交的整个经过(包括undo,redo,后台进程

WBOY
發布: 2016-06-07 15:50:42
原創
1343 人瀏覽過

语句:UPDATE TEST SET A=999 WHERE A=1; 1.首先UPDATE操作开始前 数据块读入DATA BUFFER CACHE(或者已经在内存中)。然后在修改前将要修改的数据放到回滚段(或者已经在内存中),回滚段发生变化,产生REDO。 REDO BUFFER-演示 tranID file block row colu

语句:UPDATE TEST SET A=999 WHERE A=1;

1.首先UPDATE操作开始前

数据块读入DATA BUFFER CACHE(或者已经在内存中)。然后在修改前将要修改的数据放到回滚段(或者已经在内存中),回滚段发生变化,产生REDO。

REDO BUFFER-演示

tranID file block row column value
test    4   9    -    -    1   

2.开始UPDATE操作

此时开始UPDATE操作修改读入DATA BUFFER CACHE的数据块,将1改为999,产生REDO信息记录了UNDO数据块操作。

REDO BUFFER-演示
tranID file block row column value
test    4   9    -    -    1    
 test    3   19   1     1      999

3.执行COMMIT

此时执行COMMIT提交,在REDO产生一个COMMIT标记。

执行COMMIT后,LGWR进程将重做日志缓冲区记录顺序写入当前重做日志文件中

REDO BUFFER-演示
tranID file    block row column value
test    4      9      -    -    1    
 test    3      19    1     1      999
 test  commit  SCN   TIME STAMP

Oracle更新一条数据然后提交的整个经过(包括undo,redo,后台进程


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板