Oracle數據庫系統

Oracle數據庫系統是壹個復雜的軟件系統。所謂Oracle的體系架構,是指Oracle數據庫管理系統的的組成部分和這些組成部分之間的相互關系,包括內存結構、後臺進程、物理與邏輯結構等。

下圖為Oracle數據庫體系總體圖:

Oracle數據庫的體系很復雜,復雜的原因在於它最大限度的節約內存,從上圖可以看出,它在整體上分實例和數據庫文件兩部分。

壹、實例(Instance):指數據庫服務器的內存及相關處理程序,它是Oracle的心臟。與Oracle性能關系最大的是SGA(System Global Area,即系統全局區活共享內存區),SGA包含三個部分:

1.數據緩沖區,可避免重復讀取常用的數據;

2.日誌緩沖區,提升了數據增刪改的速度,減少磁盤的讀寫而加快速度;

3.共享池,使相同的SQL語句不再編譯,提升了SQL的執行速度。

二、數據庫文件,由操作系統內的各種文件組組成。

1.Oracle數據庫邏輯結構:

1).表空間,數據庫的基本邏輯結構,是壹系列數據文件的集合;

2).段,不同類型數據在數據庫中占用的空間,有許多區組合而成;

3).區,目的是為數據壹次性預留壹個較大的空間;

4).塊,最小的存儲單位,在創建數據庫時指定。

2.Oracle數據庫物理結構:

1).數據文件(Data File),存儲數據的文件;

2).重做日誌文件(Redo Log File),負責記錄數據庫內任何數據的處理情況,可用於數據的恢復;

3).控制文件(Control File),控制和記錄數據庫的實體結構;

4).初始化參數文件(Initialization Parameter File),配置內存空間的依據;

5).口令文件(Password File),認證用戶啟動和關閉Oracle例程的權限。

Oracle OCA 考試認證

Oracle10g Certified Associate (OCA) Oracle 認證專員。考試成績通過能獲得Oracle公司為您頒發的全球認證的英文OCA證書。OCA由Oracle公司出題。OCA證書可作為各企事業單位數據庫管理人員上崗的依據。目前已成為各IT公司及相關企業爭相競聘的數據庫管理維護人才,是數據庫維護管理人員(DBA)的初級證書。

OCA考試科目:

1Z0-051: Oracle Database 11g:SQL FundamentalsI
1Z0-042: Oracle Database 10g Administration I

自學條件:

熟悉Windows或Linux操作系統;
有ACCESS或其他數據庫基礎,有壹定網絡操作的基本知識,具有高中或以上英語水平。

Oracle 的入门心得

oracle的體系太龐大了,對於初學者來說,難免會有些無從下手的感覺,什麽都想學,結果什麽都學不好,所以把學習經驗共享壹下,希望

讓剛剛入門的人對oracle有壹個總體的認識,少走壹些彎路。 壹、定位 oracle分兩大塊,壹塊是開發,壹塊是管理。開發主要是寫寫存儲過程、觸發器什麽的,還有就是用Oracle的Develop工具做form。有點類似於

程序員,需要有較強的邏輯思維和創造能力,個人覺得會冉閑量啵喬啻悍笿;管理則需要對oracle數據庫的原理有深刻的認識,有全局操縱的能力和緊密的思維,責任較大,因為壹個小的失誤就會down掉整個數據庫,相對前者來說,後者更看重經驗。 因為數據庫管理的責任重大,很少公司願意請壹個剛剛接觸oracle的人去管理數據庫。對於剛剛畢業的年輕人來說,可以先選擇做開發,有壹定經驗後轉型,去做數據庫的管理。當然,這個還是要看個人的實際情況來定。

二、學習方法 我的方法很簡單,就是:看書、思考、寫筆記、做實驗、再思考、再寫筆記 看完理論的東西,自己靜下心來想想,多問自己幾個為什麽,然後把所學和所想的知識點做個筆記;在想不通或有疑問的時候,就做做實

驗,想想怎麽會這樣,同樣的,把實驗的結果記下來。思考和做實驗是為了深入的了解這個知識點。而做筆記的過程,也是理清自己思路的過程。 學習的過程是使壹個問題由模糊到清晰,再由清晰到模糊的過程。而每次的改變都代表著妳又學到了壹個新的知識點。 學習的過程也是從點到線,從線到網,從網到面的過程。當點變成線的時候,妳會有總豁然開朗的感覺。當網到面的時候,妳就是高手了 很多網友,特別是初學的人,壹碰到問題就拿到論壇上來問,在問前,妳有沒有查過書,自己有沒有研究過,有沒有搜索壹下論壇?這就叫思維惰性。由別人來回答妳的問題,會讓妳在短時間內不費勁地弄懂這個知識點,然而通過自己的努力去研究它,不但會更深入的了解這個知識點,更重要的是在研究的過程會提高妳解決問題和分析問題的能力。總的來說,沒有鉆研的學習態度,不管學什麽東西,都不會成功的。 當然,初學的人很多時候是因為遇到問題時,無從下手,也不知道去哪裏找資料,才會到論壇上提問題的。但我認為,在提問的時候,是不是可以問別人是如何分析這個問題?從哪裏可以找到相關的資料?而不是這個題的答案是什麽?授人以魚不如授人以漁。

下面我講下我處理問題的過程

首先要知道oracle的官方網站:www.oracle.com 這裏有oracle的各種版本的數據庫、應用工具和權威的官方文檔。其次,還要知道

http://metalink.oracle.com/這裏是買了oracle服務或是oracle的合作夥伴才可以進去的,裏面有很多權威的解決方案和補丁。然後就是壹些

著名網站:asktom.oracle.com www.orafaq.net, www.dbazine.com。這裏有很多經驗之談。

遇到問題了。如果是概念上的問題,第壹時間可以找tahiti.oracle.com,這裏會給妳最詳細的解釋。如果在運行的過程中出了什麽錯誤。

可以去metalink看看。如果是想知道事務的處理的經驗之談。可以去asktom。當然。這裏只是相對而言。三、oracle的體系 oracle的體系很龐大,要學習它,首先要了解oracle的框架。在這裏,簡要的講壹下oracle的架構,讓初學者對oracle有壹個整體的認識。 1、物理結構(由控制文件、數據文件、重做日誌文件、參數文件、歸檔文件、密碼文件組成) 控制文件:包含維護和驗證數據庫完整性的必要信息、例如,控制文件用於識別數據文件和重做日誌文件,壹個數據庫至少需要壹個控制文件 數據文件:存儲數據的文件 重做日誌文件:含對數據庫所做的更改記錄,這樣萬壹出現故障可以啟用數據恢復。壹個數據庫至少需要兩個重做日誌文件 參數文件:定義Oracle 例程的特性,例如它包含調整SGA 中壹些內存結構大小的參數 歸檔文件:是重做日誌文件的脫機副本,這些副本可能對於從介質失敗中進行恢復很必要。 密碼文件:認證哪些用戶有權限啟動和關閉Oracle例程 2、邏輯結構(表空間、段、區、塊) 表空間:是數據庫中的基本邏輯結構,壹系列數據文件的集合。 段:是對象在數據庫中占用的空間 區:是為數據壹次性預留的壹個較大的存儲空間 塊:ORACLE最基本的存儲單位,在建立數據庫的時候指定 3、內存分配(SGA和PGA) SGA:是用於存儲數據庫信息的內存區,該信息為數據庫進程所共享。它包含Oracle 服務器的數據和控制信息, 它是在Oracle 服務器所駐留的

計算機的實際內存中得以分配,如果實際內存不夠再往虛擬內存中寫。 PGA:包含單個服務器進程或單個後臺進程的數據和控制信息,與幾個進程共享的SGA 正相反PGA 是只被壹個進程使用的區域,PGA 在創建進程

時分配在終止進程時回收 4、後臺進程(數據寫進程、日誌寫進程、系統監控、進程監控、檢查點進程、歸檔進程、服務進程