深刻理解數據庫的啟動和關閉
數據庫提供了幾種不同的數據庫啟動和關閉方式,本文將詳細介紹這些啟動和關閉方式之間的區別以及它們各自不同的功能,深刻理解數據庫的啟動和關閉。
一、啟動和關閉數據庫
要啟動和關閉數據庫,必須要以具有 管理員權限的用戶登陸,通常也就是以具有權限的用戶登陸。一般我們常用用戶來啟動和關閉數據庫(用戶實際上是SYS用戶以連接的同義詞)。數據庫的新版本將逐步淘汰這個內部用戶,所以我們最好還是設置DBA用戶具有權限。
二、數據庫的啟動()
啟動一個數據庫需要三個步驟:
1、 創建一個實例(非安裝階段)
2、 由實例安裝數據庫(安裝階段)
3、 打開數據庫(打開階段)
在命令中oracle數據庫啟停步驟,可以通過不同的選項來控制數據庫的不同啟動步驟。
1、
選項僅僅創建一個實例。讀取init.ora初始化參數文件、啟動后臺進程、初始化系統全局區(SGA)。Init.ora文件定義了實例的配置,包括內存結構的大小和啟動后臺進程的數量和類型等。實例名根據設置,不一定要與打開的數據庫名稱相同。當實例打開后,系統將顯示一個SGA內存結構和大小的列表,如下所示:
SQL>
例程已經啟動。
Total Area bytes
Fixed Size 70924 bytes
Size bytes
bytes
Redo 77824 bytes
2、 MOUNT
該命令創建實例并且安裝數據庫,但沒有打開數據庫。系統讀取控制文件中關于數據文件和重作日志文件的內容,但并不打開該文件。這種打開方式常在數據庫維護操作中使用,如對數據文件的更名、改變重作日志以及打開歸檔方式等。在這種打開方式下,除了可以看到SGA系統列表以外,系統還會給出"數據庫裝載完畢"的提示。
3、
該命令完成創建實例、安裝實例和打開數據庫的所有三個步驟。此時數據庫使數據文件和重作日志文件在線,通常還會請求一個或者是多個回滾段。這時系統除了可以看到前面 Mount方式下的所有提示外,還會給出一個"數據庫已經打開"的提示。此時,數據庫系統處于正常工作狀態oracle數據庫啟停步驟,可以接受用戶請求。
如果采用 或者是 MOUNT的數據庫打開命令方式,必須采用ALTER 命令來執行打開數據庫的操作。例如,如果你以 方式打開數據庫,也就是說實例已經創建,但是數據庫沒有安裝和打開。這是必須運行下面的兩條命令,數據庫才能正確啟動。
ALTER MOUNT;
ALTER OPEN;
而如果以 MOUNT方式啟動數據庫,只需要運行下面一條命令即可以打開數據庫: ALTER OPEN.
4、其他打開方式
除了前面介紹的三種數據庫打開方式選項外,還有另外其他的一些選項。
(1)
這種方式下,數據庫將被成功打開,但僅僅允許一些特權用戶(具有DBA角色的用戶)才可以使用數據庫。這種方式常用來對數據庫進行維護,如數據的導入/導出操作時不希望有其他用戶連接到數據庫操作數據。
(2) FORCE
該命令其實是強行關閉數據庫( abort)和啟動數據庫()兩條命令的一個綜合。該命令僅在關閉數據庫遇到問題不能關閉數據庫時采用。
(3) ALTER OPEN READ ONLY;
該命令在創建實例以及安裝數據庫后,以只讀方式打開數據庫,電腦資料《深刻理解數據庫的啟動和關閉》()。對于那些僅僅提供查詢功能的產品數據庫可以采用這種方式打開。
數據庫打開分為三個階段 :
1- :作用—維護數據庫系統文件,
2-mount:作用—維護用戶文件,
3-open:作用:進行數據訪問,對數據做增、刪、改、查
三、數據庫的關閉()
對于數據庫的關閉,有四種不同的關閉選項,下面對其進行一一介紹。
1、
這是數據庫關閉命令的確省選項。也就是說如果你發出這樣的命令,也即是 的意思。發出該命令后,任何新的連接都將再不允許連接到數據庫。在數據庫關閉之前,將等待目前連接的所有用戶都從數據庫中退出后才開始關閉數據庫。采用這種方式關閉數據庫,在下一次啟動時不需要進行任何的實例恢復。但需要注意一點的是,采用這種方式,也許關閉一個數據庫需要幾天時間,也許更長。
2、
這是我們常用的一種關閉數據庫的方式,想很快地關閉數據庫,但又想讓數據庫干凈的關閉,常采用這種方式。
當前正在被處理的SQL語句立即中斷,系統中任何沒有提交的事務全部回滾。如果系統中存在一個很長的未提交的事務,采用這種方式關閉數據庫也需要一段時間(該事務回滾時間)。系統不等待連接到數據庫的所有用戶退出系統,強行回滾當前所有的活動事務,然后斷開所有的連接用戶。
3、
該選項僅在 8i后才可以使用。該命令常用來計劃關閉數據庫,它使當前連接到系統且正在活動的事務執行完畢,運行該命令后,任何新的連接和事務都是不允許的。在所有活動的事務完成后,數據庫將和 同樣的方式關閉數據庫。
4、 ABORT
這是關閉數據庫的最后一招,也是在沒有任何辦法關閉數據庫的情況下才不得不采用的方式,一般不要采用。如果下列情況出現時可以考慮采用這種方式關閉數據庫。
1、 數據庫處于一種非正常工作狀態,不能用 或者 這樣的命令關閉數據庫;
2、 需要立即關閉數據庫;
3、 在啟動數據庫實例時遇到問題;
所有正在運行的SQL語句都將立即中止。所有未提交的事務將不回滾。也不等待目前連接到數據庫的用戶退出系統。下一次啟動數據庫時需要實例恢復,因此,下一次啟動可能比平時需要更多的時間。
表1可以清楚地看到上述四種不同關閉數據庫的區別和聯系。
表1 數據庫不同方式對比表
關閉方式AITN
允許新的連接× ×× ×
等待直到當前會話中止× × × √
等待直到當前事務中止× × √ √
強制,關閉所有文件× √ √ √
其中:A-Abort I- T- N-
如果你的數據庫出現問題:
1- abort;
2-;
3- ;
staru