一次事務過程與資料庫管理過程

來源:互聯網
上載者:User
對於開發人員來說,我們經常做的是啟動一個事務,執行SQL,提交事務。這就完成了我們的工作。但是,就在這些簡單的動作背後,網路和資料庫都做了些什麼呢。我們都想知道。

下面以一個執行個體來說明。
背景:使用者正運行一個串連到Oracle資料庫的用戶端應用程式,是一個員工檔案管理程式。
過程:
1.使用者修改了一筆員工檔案記錄的姓名,並單擊了“儲存”,這時用戶端應用程式通過網路向Oracle伺服器處理序發送了一條SQL UPDATE語句;
(註:關於客戶與伺服器的如何串連的過程,將另起篇幅說明。將會涉及到:Oracle Net組件、MTS、監聽器、Dispatcher等概念)
2.伺服器處理序收到UPDATE語句請求以後,在SGA的SQL區中尋找同樣的語句,如果找到了則執行。否則,伺服器處理序就檢查語句的文法,並對它進行分析,從而以最優的方法執行(這個過程叫做parsing and optimizing)。一旦這個處理完成了以後,這條語句就緩衝在SGA的SQL共用區中;
3.伺服器處理序將原來的員工的、資料拷貝到復原段(或重做資料表空間,即undo tablespace,oracle後來的版本增加了Undo tablespace功能,以取待原有的system資料表空間中的復原段的功能)。將原來的員工資料拷貝到復原段中是為了將來使用者取消事務而備用的。在這個過程完成之後,伺服器處理序修改資料庫的資料區塊以改變員工的姓名。修改後的資料庫的資料區塊此時儲存在SGA的資料庫緩衝區中。
4.伺服器處理序在SGA日誌緩衝區內記錄加滾段和資料庫塊的改變資訊。(注意:復原段的改變也同樣要寫入日誌,因為它也是事務的一部分);
5.用戶端的使用者提交事務;
6.LGWR(log writer)進程將這個事務的日誌資訊從日誌緩衝區中寫入當前的磁碟記錄檔中。當作業系統確定寫記錄檔已經正確完成時,事務才算是提交了。
7.伺服器處理序向客戶發送資訊以確認提交。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.