1、SQL、PL/SQL
作為Oracle的基本功,需要大家對SQL和PL/SQL非常的熟悉。特別是SQL里面的多表連接、子查詢、各種新版本的函數,以及PL/SQL里面的所有語法。建議大家拿出足夠的時間來研究這兩塊。不要認為這是開發人員的工作,它也是DBA的重要工作,而且對DBA的要求更高,你不但要能夠看懂,還要能夠找出問題。
學習這方面知識的要點就是:多練、多思考、多測試。
2、Oracle管理(體系結構)
這是Oracle的難點,Oracle技術博大精深,主要的難點就集中在這里面。包括Oracle的存儲管理、對象管理、內存和進程、UNDO管理、初始化參數、數據字典視圖、安全、Latch和Lock、權限和角色、資源調度、閃回、日志原理等。
學習這一塊知識的時候,一個重點是:要知道原理和本質,知道表面的東西沒有任何意義。
知道原理以后,通過實驗去證明,將原理總結出來。這一塊學習的好還是不好,直接決定了以后的一個備份恢復、優化、排錯。這一塊雖然是研究管理,但是更加注重原理和體系結構的分析和解剖。應該叫做“深入剖析Oracle體系結構”,多深都需要。在這一部分的學習中,已經學習了很多優化的內容,在學習任何一個知識點的時候,我們都離不開對性能的分析。
3、備份恢復
有了第二部分的鋪墊,這一章的學習相對有意思,前提是我們對Oracle的日志原理研究得較深,對Oracle的內存和進程研究得較深。策劃一個完美和正確的備份計劃和實施方案(具體要分析出原理),實施備份;對各種損壞進行恢復(還是要能分析出原理);另外可以做一些高難度的恢復實驗(還是老話、要能夠分析出原理)
4、優化(單實例優化)
這一塊完全是第一部分和第二部分的一個結合。這一塊的學習沒有最深,只有更深,學習方法和第二部分類似。
首先需要大家掌握一些Oracle優化方面的基礎知識,例如深入分析索引原理、分區、等待事件、時間統計模型、動態性能視圖、操作系統的一些性能優化和查看命令,例如:top、iostat、vmstat、sar、pmap、prstat、filemon、nmon、svmon等。
最關鍵的還是要做三件事情:Oracle的動態性能視圖、Oracle的報告(trace、statspack、awr、addm、ash)、執行計劃;對這三塊要熟悉和分析出來。這個部分的分析和動手實驗很重要。
5、RAC
現在RAC的使用越來越多,學習RAC的重點還是:基礎原理 + RAC優化。RAC系統的優化分為兩個步驟:RAC系統優化和單實例優化;根據RAC的基礎原理,能夠設計高性能的RAC系統,能夠分析RAC性能問題。對RAC的動態性能視圖、等待事件、報告,能夠看懂和分析。
6、Cloud Control、Data Control、Stream、Golden Gate等
對于這些工具和組件,我們熟悉其體系結構,原理,一些監控性能的工具等。學習這些部分的幾個點:熟悉體系結構、原理、搭建、監控(包括故障和性能)、排錯和優化。
7、SQL優化
為什么單獨拿出來呢?因為這部分需要持之以恒的進行研究和實驗,而且工作中幾乎是每天都要做的事情。目前這方面,有一些比較經典的書,值得大家去看看。
8、PL/SQL深度學習
在這部分學習的時候,就要時時刻刻注意性能,主要是注意測試。
9、綜合性項目實戰
模擬環境:規劃、搭建、測試、排錯、優化、分析
實戰環境:規劃、搭建、測試、排錯、優化、分析