ORACLE培訓教材之第一講_第1頁
ORACLE培訓教材之第一講_第2頁
ORACLE培訓教材之第一講_第3頁
ORACLE培訓教材之第一講_第4頁
ORACLE培訓教材之第一講_第5頁
已閱讀5頁,還剩18頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領

文檔簡介

ORACLE培訓教材之第一講ORACLE公司自86年推出版本5開始,系統(tǒng)具有分布數(shù)據(jù)庫處理功能.88年推出版本6,ORACLERDBMS(V6.0)可帶事務處理選項(TPO),提高了事務處理的速度.1992年推出了版本7,在ORACLERDBMS中可帶過程數(shù)據(jù)庫選項(proceduraldatabaseoption)和并行服務器選項(parallelserveroption),稱為ORACLE7數(shù)據(jù)庫治理系統(tǒng),它開釋了開放的關(guān)系型系統(tǒng)的真正潛力。ORACLE7的協(xié)同開發(fā)環(huán)境提供了新一代集成的軟件生命周期開發(fā)環(huán)境,可用以實現(xiàn)高生產(chǎn)率、大型事務處理及客戶/服務器結(jié)構(gòu)的應用系統(tǒng)。協(xié)同開發(fā)環(huán)境具有可移植性,支持多種數(shù)據(jù)來源、多種圖形用戶界面及多媒體、多民族語言、CASE等協(xié)同應用系統(tǒng)。ORACLE系統(tǒng)ORACLE產(chǎn)品結(jié)構(gòu)及組成ORACLE系統(tǒng)是由以RDBMS為核心的一批軟件產(chǎn)品構(gòu)成,其產(chǎn)品結(jié)構(gòu)輪廓下圖所示:ORACLE*REPORTORACLE*FORMSSQL*PLUS用戶編制的程序SQL*CALCSQL*GRAPHICORACLE*REPORTORACLE*FORMSSQL*PLUS用戶編制的程序SQL*CALCSQL*GRAPHIC程序接口程序接口(SQL執(zhí)行程序)ORACLE內(nèi)核ORACLE內(nèi)核(RDBMS)操作系統(tǒng)操作系統(tǒng)數(shù)據(jù)字典DD數(shù)據(jù)字典DD數(shù)據(jù)庫DBORACLE系統(tǒng)特點ORACLE公司于1979年,第一推出基于SQL標準的關(guān)系數(shù)據(jù)庫產(chǎn)品,可在100多種硬件平臺上運行(所括微機、工作站、小型機、中型機和大型機),支持專門多種操作系統(tǒng)。用戶的ORACLE應用可方便地從一種運算機配置移至另一種運算機配置上。ORACLE的分布式結(jié)構(gòu)可將數(shù)據(jù)和應用駐留在多臺運算機上,而相互間的通信是透亮的。1992年6月ORACLE公司推出的ORACLE7協(xié)同服務器數(shù)據(jù)庫,使關(guān)系數(shù)據(jù)庫技術(shù)邁上了新臺階。依照IDG(國際數(shù)據(jù)集團)1992年全球UNIX數(shù)據(jù)庫市場報告,ORACLE占市場銷售量50%。它之因此倍受用戶喜愛是因為它有以下突出的特點:支持大數(shù)據(jù)庫、多用戶的高性能的事務處理。ORACLE支持最大數(shù)據(jù)庫,其大小可到幾百千兆,可充分利用硬件設備。支持大量用戶同時在同一數(shù)據(jù)上執(zhí)行各種數(shù)據(jù)應用,并使數(shù)據(jù)爭用最小,保證數(shù)據(jù)一致性。系統(tǒng)愛護具有高的性能,ORACLE每天可連續(xù)24小時工作,正常的系統(tǒng)操作(后備或個別運算機系統(tǒng)故障)可不能中斷數(shù)據(jù)庫的使用。可操縱數(shù)據(jù)庫數(shù)據(jù)的可用性,可在數(shù)據(jù)庫級或在子數(shù)據(jù)庫級上操縱。ORACLE遵守數(shù)據(jù)存取語言、操作系統(tǒng)、用戶接口和網(wǎng)絡通信協(xié)議的工業(yè)標準。因此它是一個開放系統(tǒng),愛護了用戶的投資。美國標準化和技術(shù)研究所(NIST)對ORACLE7SERVER進行檢驗,100%地與ANSI/ISOSQL89標準的二級相兼容。實施安全性操縱和完整性操縱。ORACLE為限制各監(jiān)控數(shù)據(jù)存取提供系統(tǒng)可靠的安全性。ORACLE實施數(shù)據(jù)完整性,為可同意的數(shù)據(jù)指定標準。支持分布式數(shù)據(jù)庫和分布處理。ORACLE為了充分利用運算機系統(tǒng)和網(wǎng)絡,承諾將處理分為數(shù)據(jù)庫服務器和客戶應用程序,所有共享的數(shù)據(jù)治理由數(shù)據(jù)庫治理系統(tǒng)的運算機處理,而運行數(shù)據(jù)庫應用的工作站集中于說明和顯示數(shù)據(jù)。通過網(wǎng)絡連接的運算機環(huán)境,ORACLE將存放在多臺運算機上的數(shù)據(jù)組合成一個邏輯數(shù)據(jù)庫,可被全部網(wǎng)絡用戶存取。分布式系統(tǒng)像集中式數(shù)據(jù)庫一樣具有透亮性和數(shù)據(jù)一致性。具有可移植性、可兼容性和可連接性。由于ORACLE軟件可在許多不同的操作系統(tǒng)上運行,以致ORACLE上所開發(fā)的應用可移植到任何操作系統(tǒng),只需專門少修改或不需修改。ORACLE軟件同工業(yè)標準相兼容,包括許多工業(yè)標準的操作系統(tǒng),所開發(fā)應用系統(tǒng)可在任何操作系統(tǒng)上運行??蛇B接性是指ORALCE承諾不同類型的運算機和操作系統(tǒng)通過網(wǎng)絡可共享信息。ORACLE數(shù)據(jù)庫系統(tǒng)的體系結(jié)構(gòu)ORACLE數(shù)據(jù)庫系統(tǒng)為具有治理ORACLE數(shù)據(jù)庫功能的運算機系統(tǒng)。每一個運行的ORACLE數(shù)據(jù)庫與一個ORACLE實例(INSTANCE)相聯(lián)系。一個ORACLE實例為存取和操縱一數(shù)據(jù)庫的軟件機制。每一次在數(shù)據(jù)庫服務器上啟動一數(shù)據(jù)庫時,稱為系統(tǒng)全局區(qū)(SYSTEMGLOBALAREA)的一內(nèi)存區(qū)(簡稱SGA)被分配,有一個或多個ORACLE進程被啟動。該SGA和ORACLE進程的結(jié)合稱為一個ORACLE數(shù)據(jù)庫實例。一個實例的SGA和進程為治理數(shù)據(jù)庫數(shù)據(jù)、為該數(shù)據(jù)庫一個或多個用戶服務而工作。在ORACLE系統(tǒng)中,第一是實例啟動,然后由實例裝配(MOUNT)一數(shù)據(jù)庫。在松耦合系統(tǒng)中,在具有ORACLEPARALLELSERVER選項時,單個數(shù)據(jù)庫可被多個實例裝配,即多個實例共享同一物理數(shù)據(jù)庫。ORACLE實例的進程結(jié)構(gòu)和內(nèi)存結(jié)構(gòu)進程結(jié)構(gòu)進程是操作系統(tǒng)中的一種機制,它可執(zhí)行一系列的操作步。在有些操作系統(tǒng)中使用作業(yè)(JOB)或任務(TASK)的術(shù)語。一個進程通常有它自己的專用儲備區(qū)。ORACLE進程的體系結(jié)構(gòu)設計使性能最大。ORACLE實例有兩種類型:單進程實例和多進程實例。單進程ORACLE(又稱單用戶ORACLE)是一種數(shù)據(jù)庫系統(tǒng),一個進程執(zhí)行全部ORACLE代碼。由于ORACLE部分和客戶應用程序不能分別以進程執(zhí)行,因此ORACLE的代碼和用戶的數(shù)據(jù)庫應用是單個進程執(zhí)行。在單進程環(huán)境下的ORACLE實例,僅承諾一個用戶可存取。例如在MS-DOS上運行ORACLE。多進程ORACLE實例(又稱多用戶ORACLE)使用多個進程來執(zhí)行ORACLE的不同部分,關(guān)于每一個連接的用戶都有一個進程。在多進程系統(tǒng)中,進程分為兩類:用戶進程和ORACLE進程。當一用戶運行一應用程序,如PRO*C程序或一個ORACLE工具(如SQL*PLUS),為用戶運行的應用建立一個用戶進程。ORACLE進程又分為兩類:服務器進程和后臺進程。服務器進程用于處理連接到該實例的用戶進程的要求。當應用和ORACELE是在同一臺機器上運行,而不再通過網(wǎng)絡,一樣將用戶進程和它相應的服務器進程組合成單個的進程,可降低系統(tǒng)開銷。然而,當應用和ORACLE運行在不同的機器上時,用戶進程通過一個分離服務器進程與ORACLE通信。它可執(zhí)行下列任務:對應用所發(fā)出的SQL語句進行語法分析和執(zhí)行。從磁盤(數(shù)據(jù)文件)中讀入必要的數(shù)據(jù)塊到SGA的共享數(shù)據(jù)庫緩沖區(qū)(該塊不在緩沖區(qū)時)。將結(jié)果返回給應用程序處理。系統(tǒng)為了使性能最好和和諧多個用戶,在多進程系統(tǒng)中使用一些附加進程,稱為后臺進程。在許多操作系統(tǒng)中,后臺進程是在實例啟動時自動地建立。一個ORACLE實例能夠有許多后臺進程,但它們不是一直存在。后臺進程的名字為:DBWR數(shù)據(jù)庫寫入程序LGWR日志寫入程序CKPT檢查點SMON系統(tǒng)監(jiān)控PMON進程監(jiān)控ARCH歸檔RECO復原LCKn封鎖Dnnn調(diào)度進程Snnn服務器每個后臺進程與ORACLE數(shù)據(jù)庫的不同部分交互。下面對后臺進程的功能作簡單介紹:DBWR進程:該進程執(zhí)行將緩沖區(qū)寫入數(shù)據(jù)文件,是負責緩沖儲備區(qū)治理的一個ORACLE后臺進程。當緩沖區(qū)中的一緩沖區(qū)被修改,它被標志為“弄臟”,DBWR的要緊任務是將“弄臟”的緩沖區(qū)寫入磁盤,使緩沖區(qū)保持“潔凈”。由于緩沖儲備區(qū)的緩沖區(qū)填入數(shù)據(jù)庫或被用戶進程弄臟,未用的緩沖區(qū)的數(shù)目減少。當未用的緩沖區(qū)下降到專門少,以致用戶進程要從磁盤讀入塊到內(nèi)存儲備區(qū)時無法找到未用的緩沖區(qū)時,DBWR將治理緩沖儲備區(qū),使用戶進程總可得到未用的緩沖區(qū)。ORACLE采納LRU(LEASTRECENTLYUSED)算法(最近最少使用算法)保持內(nèi)存中的數(shù)據(jù)塊是最近使用的,使I/O最小。在下列情形預示DBWR要將弄臟的緩沖區(qū)寫入磁盤:當一個服務器進程將一緩沖區(qū)移入“弄臟”表,該弄臟表達到臨界長度時,該服務進程將通知DBWR進行寫。該臨界長度是為參數(shù)DB-BLOCK-WRITE-BATCH的值的一半。當一個服務器進程在LRU表中查找DB-BLOCK-MAX-SCAN-CNT緩沖區(qū)時,沒有查到未用的緩沖區(qū),它停止查找并通知DBWR進行寫。顯現(xiàn)超時(每次3秒),DBWR將通知本身。當顯現(xiàn)檢查點時,LGWR將通知DBWR在前兩種情形下,DBWR將弄臟表中的塊寫入磁盤,每次可寫的塊數(shù)由初始化參數(shù)DB-BLOCK-WRITE-BATCH所指定。假如弄臟表中沒有該參數(shù)指定塊數(shù)的緩沖區(qū),DBWR從LUR表中查找另外一個弄臟緩沖區(qū)。假如DBWR在三秒內(nèi)未活動,則顯現(xiàn)超時。在這種情形下DBWR對LRU表查找指定數(shù)目的緩沖區(qū),將所找到任何弄臟緩沖區(qū)寫入磁盤。每當顯現(xiàn)超時,DBWR查找一個新的緩沖區(qū)組。每次由DBWR查找的緩沖區(qū)的數(shù)目是為寢化參數(shù)DB-BLOCK-WRITE-BATCH的值的二倍。假如數(shù)據(jù)庫空運轉(zhuǎn),DBWR最終將全部緩沖區(qū)儲備區(qū)寫入磁盤。在顯現(xiàn)檢查點時,LGWR指定一修改緩沖區(qū)表必須寫入到磁盤。DBWR將指定的緩沖區(qū)寫入磁盤。在有些平臺上,一個實例可有多個DBWR。在如此的實例中,一些塊可寫入一磁盤,另一些塊可寫入其它磁盤。參數(shù)DB-WRITERS操縱DBWR進程個數(shù)。LGWR進程:該進程將日志緩沖區(qū)寫入磁盤上的一個日志文件,它是負責治理日志緩沖區(qū)的一個ORACLE后臺進程。LGWR進程將自上次寫入磁盤以來的全部日志項輸出,LGWR輸出:當用戶進程提交一事務時寫入一個提交記錄。每三秒將日志緩沖區(qū)輸出。當日志緩沖區(qū)的1/3已滿時將日志緩沖區(qū)輸出。當DBWR將修改緩沖區(qū)寫入磁盤時則將日志緩沖區(qū)輸出。LGWR進程同步地寫入到活動的鏡象在線日志文件組。假如組中一個文件被刪除或不可用,LGWR 可連續(xù)地寫入該組的其它文件。日志緩沖區(qū)是一個循環(huán)緩沖區(qū)。當LGWR將日志緩沖區(qū)的日志項寫入日志文件后,服務器進程可將新的日志項寫入到該日志緩沖區(qū)。LGWR通常寫得專門快,可確保日志緩沖區(qū)總有空間可寫入新的日志項。注意:有時候當需要更多的日志緩沖區(qū)時,LWGR在一個事務提交前就將日志項寫出,而這些日志項僅當在以后事務提交后才永久化。ORACLE使用快速提交機制,當用戶發(fā)出COMMIT語句時,一個COMMIT記錄趕忙放入日志緩沖區(qū),但相應的數(shù)據(jù)緩沖區(qū)改變是被延遲,直到在更有效時才將它們寫入數(shù)據(jù)文件。當一事務提交時,被賦給一個系統(tǒng)修改號(SCN),它同事務日志項一起記錄在日志中。由于SCN記錄在日志中,以致在并行服務器選項配置情形下,復原操作能夠同步。CKPT進程:該進程在檢查點顯現(xiàn)時,對全部數(shù)據(jù)文件的標題進行修改,指示該檢查點。在通常的情形下,該任務由LGWR執(zhí)行。然而,假如檢查點明顯地降低系統(tǒng)性能時,可使CKPT進程運行,將原先由LGWR進程執(zhí)行的檢查點的工作分離出來,由CKPT進程實現(xiàn)。關(guān)于許多應用情形,CKPT進程是不必要的。只有當數(shù)據(jù)庫有許多數(shù)據(jù)文件,LGWR在檢查點時明顯地降低性能才使CKPT運行。CKPT進程不將塊寫入磁盤,該工作是由DBWR完成的。初始化參數(shù)CHECKPOINT-PROCESS操縱CKPT進程的使能或使不能。缺省時為FALSE,即為使不能。SMON進程:該進程實例啟動時執(zhí)行實例復原,還負責清理不再使用的臨時段。在具有并行服務器選項的環(huán)境下,SMON對有故障CPU或?qū)嵗M行實例復原。SMON進程有規(guī)律地被呼醒,檢查是否需要,或者其它進程發(fā)覺需要時能夠被調(diào)用。PMON進程:該進程在用戶進程顯現(xiàn)故障時執(zhí)行進程復原,負責清理內(nèi)儲備區(qū)和開釋該進程所使用的資源。例:它要重置活動事務表的狀態(tài),開釋封鎖,將該故障的進程的ID從活動進程表中移去。PMON還周期地檢查調(diào)度進程(DISPATCHER)和服務器進程的狀態(tài),假如已死,則重新啟動(不包括有意刪除的進程)。PMON有規(guī)律地被呼醒,檢查是否需要,或者其它進程發(fā)覺需要時能夠被調(diào)用。RECO進程:該進程是在具有分布式選項時所使用的一個進程,自動地解決在分布式事務中的故障。一個結(jié)點RECO后臺進程自動地連接到包含有懸而未決的分布式事務的其它數(shù)據(jù)庫中,RECO自動地解決所有的懸而不決的事務。任何相應于已處理的懸而不決的事務的行將從每一個數(shù)據(jù)庫的懸掛事務表中刪去。當一數(shù)據(jù)庫服務器的RECO后臺進程試圖建立同一遠程服務器的通信,假如遠程服務器是不可用或者網(wǎng)絡連接不能建立時,RECO自動地在一個時刻間隔之后再次連接。RECO后臺進程僅當在承諾分布式事務的系統(tǒng)中顯現(xiàn),而且DISTRIBUTED–TRANSACTIONS參數(shù)是大于0。ARCH進程:該進程將已填滿的在線日志文件拷貝到指定的儲備設備。當日志是為ARCHIVELOG使用方式、并可自動地歸檔時ARCH進程才存在。LCKn進程:是在具有并行服務器選件環(huán)境下使用,可多至10個進程(LCK0,LCK1……,LCK9),用于實例間的封鎖。Dnnn進程(調(diào)度進程):該進程承諾用戶進程共享有限的服務器進程(SERVERPROCESS)。沒有調(diào)度進程時,每個用戶進程需要一個專用服務進程(DEDICATEDSERVERPROCESS)。關(guān)于多線索服務器(MULTI-THREADEDSERVER)可支持多個用戶進程。假如在系統(tǒng)中具有大量用戶,多線索服務器可支持大量用戶,專門在客戶_服務器環(huán)境中。在一個數(shù)據(jù)庫實例中可建立多個調(diào)度進程。對每種網(wǎng)絡協(xié)議至少建立一個調(diào)度進程。數(shù)據(jù)庫治理員依照操作系統(tǒng)中每個進程可連接數(shù)目的限制決定啟動的調(diào)度程序的最優(yōu)數(shù),在實例運行時可增加或刪除調(diào)度進程。多線索服務器需要SQL*NET版本2或更后的版本。在多線索服務器的配置下,一個網(wǎng)絡接收器進程等待客戶應用連接要求,并將每一個發(fā)送到一個調(diào)度進程。假如不能將客戶應用連接到一調(diào)度進程時,網(wǎng)絡接收器進程將啟動一個專用服務器進程。該網(wǎng)絡接收器進程不是ORACLE實例的組成部分,它是處理與ORACLE有關(guān)的網(wǎng)絡進程的組成部分。在實例啟動時,該網(wǎng)絡接收器被打開,為用戶連接到ORACLE建立一通信路徑,然后每一個調(diào)度進程把連接要求的調(diào)度進程的地址給予于它的接收器。當一個用戶進程作連接要求時,網(wǎng)絡接收器進程分析要求并決定該用戶是否可使用一調(diào)度進程。假如是,該網(wǎng)絡接收器進程返回該調(diào)度進程的地址,之后用戶進程直截了當連接到該調(diào)度進程。有些用戶進程不能調(diào)度進程通信(假如使用SQL*NET往常的版本的用戶),網(wǎng)絡接收器進程不能將如此用戶連接到一調(diào)度進程。在這種情形下,網(wǎng)絡接收器建立一個專用服務器進程,建立一種合適的連接。2)、ORACLE內(nèi)存結(jié)構(gòu)ORACLE在內(nèi)存儲備下列信息:執(zhí)行的程序代碼。連接的會話信息程序執(zhí)行期間所需數(shù)據(jù)和共享的信息儲備在外儲備上的緩沖信息。ORACLE具有下列差不多的內(nèi)存結(jié)構(gòu):軟件代碼區(qū)系統(tǒng)全局區(qū),包括數(shù)據(jù)庫緩沖儲備區(qū)、日志緩沖區(qū)和共享池.程序全局區(qū),包括棧區(qū)和數(shù)據(jù)區(qū).排序區(qū)軟件代碼區(qū)用于儲備正在執(zhí)行的或能夠執(zhí)行的程序代碼。軟件區(qū)是只讀,可安裝成共享或非共享。ORACLE系統(tǒng)程序是可共享的,以致多個ORACLE用戶可存取它,而不需要在內(nèi)存有多個副本。用戶程序能夠共享也能夠不共享。系統(tǒng)全局區(qū)為一組由ORACLE分配的共享的內(nèi)存結(jié)構(gòu),可包含一個數(shù)據(jù)庫實例的數(shù)據(jù)或操縱信息。假如多個用戶同時連接到同一實例時,在實例的SGA中數(shù)據(jù)可為多個用戶所共享,因此又稱為共享全局區(qū)。當實例起動時,SGA的儲備自動地被分配;當實例關(guān)閉時,該儲備被回收。所有連接到多進程數(shù)據(jù)庫實例的全部用戶可自動地被分配;當實例關(guān)閉時,該儲備被回收。所有連接到多進程數(shù)據(jù)庫實例的全部用戶可使用其SGA中的信息,但僅僅有幾個進程可寫入信息。在SGA中儲備信息將內(nèi)存劃分成幾個區(qū):數(shù)據(jù)庫緩沖儲備區(qū)、日志緩沖區(qū)、共享池、要求和響應隊列、數(shù)據(jù)字典儲備區(qū)和其它各種信息。程序全局區(qū)PGA是一個內(nèi)存區(qū),包含單個進程的數(shù)據(jù)和操縱信息,因此又稱為進程全局區(qū)(PROCESSGLOBALAREA)。排序區(qū)排序需要內(nèi)存空間,ORACLE利用該內(nèi)存排序數(shù)據(jù),這部分空間稱為排序區(qū)。排序區(qū)存在于要求排序的用戶進程的內(nèi)存中,該空間的大小為適就排序數(shù)據(jù)量的大小,可增長,但受初始化參數(shù)SORT-AREA-SIZER所限制。ORACLE的配置方案所有連接到ORACLE的用戶必須執(zhí)行兩個代碼模塊可存取一個ORACLE數(shù)據(jù)庫實例:應用或ORACLE工具:一數(shù)據(jù)庫用戶執(zhí)行一數(shù)據(jù)庫應用或一個ORACLE工具,可向ORACLE數(shù)據(jù)庫發(fā)出SQL語句。ORACLE服務器程序:負責說明和處理應用中的SQL語句。在多進程實例中,連接用戶的代碼可按下列三種方案之一配置:關(guān)于每一個用戶,其數(shù)據(jù)庫應用程序和服務器程序組合成單個用戶進程關(guān)于每一個用戶,其數(shù)據(jù)庫應用是由用戶進程所運行,并有一個專用服務器進程。執(zhí)行ORACLE服務器的代碼。如此的配置稱為專用服務器體系結(jié)構(gòu)執(zhí)行數(shù)據(jù)庫應用的進程不同于執(zhí)行ORACLE服務器代碼的進程,而且每一個服務器進程(執(zhí)行ORACLE服務器代碼)可服務于多個用戶進程,如此的配置稱為多線索服務器體系結(jié)構(gòu)。USER/SERVER進程相結(jié)合的結(jié)構(gòu)在這種配置下,數(shù)據(jù)庫應用和ORACLE服務器程序是在同一個進程中運行,該進程稱為用戶進程。這種ORACLE配置有時稱為單任務ORACLE(single_taskORACLE),該配置適用于如此的操作系統(tǒng),它可在同一進程中的數(shù)據(jù)庫應用和ORACLE代碼之間愛護一個隔離,該隔離是為數(shù)據(jù)安全性和完整性所需。其中程序接口(programinterface)是負責ORACLE服務器代碼的隔離和愛護,在數(shù)據(jù)庫應用和ORACLE用戶程序之間傳送數(shù)據(jù)。使用專用服務器進程的系統(tǒng)結(jié)構(gòu)使用專用服務器進程的ORACLE系統(tǒng)在兩臺運算機上運行。在這種系統(tǒng)中,在一運算機上用戶進程執(zhí)行數(shù)據(jù)庫應用,而在另一臺運算機上的服務器進程執(zhí)行相應的ORACLE服務器代碼,這兩個進程是分離的。為每個用戶進程建立的不同的服務器進程稱為專用服務器進程,因為該服務器進程僅對相連的用戶進程起作用。這種配置又稱為兩任務ORACLE。每一個連接到ORACLE的用戶進程有一個相應的專用服務進程。這種系統(tǒng)結(jié)構(gòu)承諾客戶應用是有工作站上執(zhí)行,通過網(wǎng)絡與運行ORACLE的運算機通信。當客戶應用和ORACLE服務器代碼是在同一臺運算機上執(zhí)行時,這種結(jié)構(gòu)也可用。多線索服務器的系統(tǒng)結(jié)構(gòu)多線索服務器配置承諾許多用戶進程共享專門少服務器進程。在沒有多線索服務器的配置中,每一個用戶進程需要自己的專用服務器進程。在具有多線索服務器的配置中,許多用戶進程連接到調(diào)度進程,由調(diào)度進程將客戶要求發(fā)送到一個共享服務器進程。多線索服務器配置的優(yōu)點是降低系統(tǒng)開銷,增加用戶個數(shù)。該系統(tǒng)中需要下列類型的進程:網(wǎng)絡接收器進程,將用戶進程連接到調(diào)度進程和專用服務器進程。一個或多個調(diào)度進程一個或多個共享服務器進程其中網(wǎng)絡接收器進程等待新來的連接要求,決定每一用戶進程能否用共享服務器進程。假如能夠使用,接收器進程將一調(diào)度進程的地址返回給用戶進程。假如用戶進程要求一專用服務器,該接收器進程將建立一個專用服務器進程,將用戶進程連接到該專用服務器進程。關(guān)于數(shù)據(jù)庫客戶機所使用的每種網(wǎng)絡協(xié)議至少配置一個調(diào)度進程,并啟動它。當用戶作一次調(diào)用時,調(diào)度進程將要求放置在SGA的要求隊列中,由可用的共享服務器進程獵取。共享服務器進程為完成每一個用戶進程的要求作所有必要的數(shù)據(jù)庫調(diào)用。當服務器完成要求時,將結(jié)果返回到調(diào)度進程的隊列,然后由調(diào)度進程將完成的要求返回給用戶進程。共享服務器進程:除共享服務器進程不是連接指定的用戶進程外,共享服務器進程和專用服務器進程提供相同的功能,一個共享服務器進程在多線索服務器的配置中可為任何客戶要求服務。一個共享服務器進程的SGA不包含有與用戶相關(guān)的數(shù)據(jù),其信息可為所有共享服務器進程存取,它僅包含??臻g、進程指定變量。所有與會話有關(guān)的信息是包含有SGA中。每一個共享服務器進程可存取全部會話的數(shù)據(jù)空間,以致任何服務進程可處理任何會話的要求。關(guān)于每一個會話的數(shù)據(jù)空間是在SGA中分配空間。ORACLE依照要求隊列的長度可動態(tài)地調(diào)整共享服務器進程??山⒌墓蚕矸掌鬟M程將要求放到要求隊列。一個用戶要求是對數(shù)據(jù)庫的一次程序接口調(diào)用,為SQL語句。在SGA中要求隊列對實例的全部調(diào)度進程是公用的。服務器進程為新要求檢查公用要求隊列,按先進先出的原則從隊列檢出一個要求,然后為完成該要求對數(shù)據(jù)庫作必要的調(diào)用。共享服務器進程將響應放在調(diào)度進程的響應隊列。每一個調(diào)度進程在SGA中有自己的響應隊列,每個調(diào)度進程負責將完成的要求回送給相應的用戶進程。3.ORACLE運行使用專用服務進程的ORACLE的運行在這種配置下,ORACLE運行過程如下:數(shù)據(jù)庫服務器運算機當前正在運行ORACLE(后臺進程)。在一客戶工作站運行一個數(shù)據(jù)庫應用(為用戶進程),如SQL*PLUS??蛻魬檬褂肧QL*NETDRIVER建立對服務器的連接。數(shù)據(jù)庫服務器運算機當前正運行合適的SQL*NETDRIVER,該機上接收器進程檢出客戶數(shù)據(jù)庫應用的連接要求,并在該機上為用戶進程建立專用服務器進程。用戶發(fā)出單個SQL語句。專用服務器進程接收該語句,在此處有兩種方法處理SQL語句:假如在共享池一共享SQL區(qū)中包含有相同SQL語句時,該服務器進程可利用已存在的共享SQL區(qū)執(zhí)行客戶的SQL語句。假如在共享池中沒有一個SQL區(qū)包含有相同的SQL語句時,在共享池中為該語句分配一新的共享SQL區(qū)。在每一種情形,在會話的PGA中建立一個專用SQL區(qū),專用服務器進程檢查用戶對查詢數(shù)據(jù)的存取權(quán)限。(6)假如需要,服務器進程從數(shù)據(jù)文件中檢索數(shù)據(jù)塊,或者可使用已儲備在實例SGA中的緩沖儲備區(qū)的數(shù)據(jù)塊。(7)服務器進程執(zhí)行儲備在共享SQL區(qū)中的SQL語句。數(shù)據(jù)第一在SGA中修改,由DBWR進程在最有效時將它寫入磁盤。LGWR進程在在線日志文件中記錄用戶提交要求的事務。(8)假如要求成功,服務器將通過網(wǎng)絡發(fā)送一信息。假如要求不成功,將發(fā)送相應的錯誤信息。(9)在整個過程中,其它的后臺進程是運行的,同時注意需要干預的條件。另外,ORACLE治理其它事務,防止不同事務之間要求同一數(shù)據(jù)的競爭。2)使用多線索服務器的ORACLE的運行在這種配置下,ORACLE運行過程如下:一數(shù)據(jù)庫服務器運算機運行使用多線索服務器配置的ORACLE。在一客戶工作站運行一數(shù)據(jù)庫應用(在一用戶進程中)??蛻魬煤线m的SQL*NET驅(qū)動器試圖建立到數(shù)據(jù)庫服務器運算機的連接。數(shù)據(jù)庫服務器運算機當前運行合適的SQL*NET驅(qū)動器,它的網(wǎng)絡接收器進程檢出用戶進程的連接要求,并決定用戶進程如何連接。假如用戶是使用SQL*NET版本2,該網(wǎng)絡接收器通知用戶進程使用一個可用的調(diào)度進程的地址重新連接。用戶發(fā)出單個SQL語句調(diào)度進程將用戶進程的要求放入要求隊列,該隊列位于SGA中,可為所有調(diào)度進程共享。一個可用共享服務器檢驗公用調(diào)度進程要求隊列,并從隊列中檢出下一個SQL語句。然后處理該SQL語句,同前一(5),(6)和(7)。注意:會話的專用SQL區(qū)是建立在SGA中。一當共享服務器進程完成SQL處理,該進程將結(jié)果放置發(fā)入該要求的調(diào)度進程的響應隊列。調(diào)度進程檢查它的響應隊列,并將完成的要求送回要求的用戶進程。4.數(shù)據(jù)庫結(jié)構(gòu)和空間治理一個ORACLE數(shù)據(jù)庫是數(shù)據(jù)的集合,被處理成一個單位。一個ORACLE數(shù)據(jù)庫有一個物理結(jié)構(gòu)和一個邏輯結(jié)構(gòu)。物理數(shù)據(jù)庫結(jié)構(gòu)(physicaldatabasestructure)是由構(gòu)成數(shù)據(jù)庫的操作系統(tǒng)文件所決定。每一個ORACLE數(shù)據(jù)庫是由三種類型的文件組成:數(shù)據(jù)文件、日志文件和操縱文件。數(shù)據(jù)庫的文件為數(shù)據(jù)庫信息提供真正的物理儲備。邏輯數(shù)據(jù)庫結(jié)構(gòu)是用戶所涉及的數(shù)據(jù)庫結(jié)構(gòu)。一個ORACLE數(shù)據(jù)庫的邏輯結(jié)構(gòu)由下列因素決定:一個或多個表空間數(shù)據(jù)庫模式對象(即表、視圖、索引、集合、序列、儲備過程)邏輯儲備結(jié)構(gòu)如表空間(dataspace)、段(segment)和范疇將支配一個數(shù)據(jù)庫的物理空間如何使用。模式對象(schemaobject)用它們之間的聯(lián)系組成了一個數(shù)據(jù)庫的關(guān)系設計。物理結(jié)構(gòu)數(shù)據(jù)文件每一個ORACLE數(shù)據(jù)庫有一個或多個物理的數(shù)據(jù)文件(datafile)。一個數(shù)據(jù)庫的數(shù)據(jù)文件包含全部數(shù)據(jù)庫數(shù)據(jù)。邏輯數(shù)據(jù)庫結(jié)構(gòu)(如表、索引)的數(shù)據(jù)物理地儲備在數(shù)據(jù)庫的數(shù)據(jù)文件中。數(shù)據(jù)文件有下列特點:一個數(shù)據(jù)文件僅與一個數(shù)據(jù)庫聯(lián)系。一旦建立,數(shù)據(jù)文件不能改變大小一個表空間(數(shù)據(jù)庫儲備的邏輯單位)由一個或多個數(shù)據(jù)文件組成。數(shù)據(jù)文件中的數(shù)據(jù)在需要時能夠讀取并儲備在ORACLE內(nèi)儲備區(qū)中。例如:用戶要存取數(shù)據(jù)庫一表的某些數(shù)據(jù),假如要求信息不在數(shù)據(jù)庫的內(nèi)存儲備區(qū)內(nèi),則從相應的數(shù)據(jù)文件中讀取并儲備在內(nèi)存。當修改和插入新數(shù)據(jù)時,不必趕忙寫入數(shù)據(jù)文件。為了減少磁盤輸出的總數(shù),提高性能,數(shù)據(jù)儲備在內(nèi)存,然后由ORACLE后臺進程DBWR決定如何將其寫入到相應的數(shù)據(jù)文件。日志文件每一個數(shù)據(jù)庫有兩個或多個日志文件(redologfile)的組,每一個日志文件組用于收集數(shù)據(jù)庫日志。日志的要緊功能是記錄對數(shù)據(jù)所作的修改,因此對數(shù)據(jù)庫作的全部修改是記錄在日志中。在顯現(xiàn)故障時,假如不能將修改數(shù)據(jù)永久地寫入數(shù)據(jù)文件,則可利用日志得到該修改,因此從可不能丟失已有操作成果。日志文件要緊是愛護數(shù)據(jù)庫以防止故障。為了防止日志文件本身的故障,ORACLE承諾鏡象日志(mirroredredolog),以致可在不同磁盤上愛護兩個或多個日志副本。日志文件中的信息僅在系統(tǒng)故障或介質(zhì)故障復原數(shù)據(jù)庫時使用,這些故障阻止將數(shù)據(jù)庫數(shù)據(jù)寫入到數(shù)據(jù)庫的數(shù)據(jù)文件。然而任何丟失的數(shù)據(jù)在下一次數(shù)據(jù)庫打開時,ORACLE自動地應用日志文件中的信息來復原數(shù)據(jù)庫數(shù)據(jù)文件。操縱文件每一ORACLE數(shù)據(jù)庫有一個操縱文件(controlfile),它記錄數(shù)據(jù)庫的物理結(jié)構(gòu),包含下列信息類型:數(shù)據(jù)庫名;數(shù)據(jù)庫數(shù)據(jù)文件和日志文件的名字和位置;數(shù)據(jù)庫建立日期。為了安全起見,承諾操縱文件被鏡象。每一次ORACLE數(shù)據(jù)庫的實例啟動時,它的操縱文件用于標識數(shù)據(jù)庫和日志文件,當著手數(shù)據(jù)庫操作時它們必須被打開。當數(shù)據(jù)庫的物理組成更換時,ORACLE自動更換該數(shù)據(jù)庫的操縱文件。數(shù)據(jù)復原時,也要使用操縱文件。邏輯結(jié)構(gòu)數(shù)據(jù)庫邏輯結(jié)構(gòu)包含表空間、段、范疇(extent)、數(shù)據(jù)塊和模式對象。表空間一個數(shù)據(jù)庫劃分為一個或多個邏輯單位,該邏輯單位稱為表空間(TABLESPACE)。一個表空間可將相關(guān)的邏輯結(jié)構(gòu)組合在一起。DBA可利用表空間作下列工作:操縱數(shù)據(jù)庫數(shù)據(jù)的磁盤分配。將確定的空間份額分配給數(shù)據(jù)庫用戶。通過使單個表空間在線或離線,操縱數(shù)據(jù)的可用性。執(zhí)行部分數(shù)據(jù)庫后備或復原操作。為提高性能,跨過設備分配數(shù)據(jù)儲備。數(shù)據(jù)庫、表空間和數(shù)據(jù)文件之間的關(guān)系如下圖所示:DatabaseSYSTEMDATATablespaceTablespaceSYSTEMDATATablespaceTablespaceDTATAFILE1(2MB)DATAFILE2(2MB)DATAFILE3(2MB)Driver1Driver2。每個數(shù)據(jù)庫可邏輯劃分為一個或多個表空間。每一個表空間是由一個或多個數(shù)據(jù)文件組成,該表空間物理地儲備表空間中全部邏輯結(jié)構(gòu)的數(shù)據(jù)。DBA能夠建立新的表空間,可為表空間增加數(shù)據(jù)文件或可刪除數(shù)據(jù)文件,設置或更換缺省的段儲備位置。每一個ORACLE數(shù)據(jù)庫包含有一個名為SYSTEM的表空間,在數(shù)據(jù)庫建立是自動建立。在該表空間中總包含有整個數(shù)據(jù)庫的數(shù)據(jù)字典表。最小的數(shù)據(jù)庫可只需要SYSTEM表空間。該表空間必須總是在線。表和儲備的PL/SQL程序單元(過程、函數(shù)、包和觸發(fā)器)的全部儲備數(shù)據(jù)是儲備在SYSTEM表空間中。假如這些PL/SQL對象是為數(shù)據(jù)庫建的,DBA在SYSTEM表空間中需要規(guī)劃這些對象所需要的空間。表空間利用增加數(shù)據(jù)文件擴大表空間,表空間的大小為組成該表空間的數(shù)據(jù)文件大小的和。DBA能夠使ORACLE數(shù)據(jù)庫中任何表空間(除SYSTEM表空間外)在線(ONLINE)或離線(OFFLINE)。表空間通常是在線,以致它所包含的數(shù)據(jù)對數(shù)據(jù)庫用戶是可用的。當表空間為離線時,其數(shù)據(jù)不可使用。在下列情形下,DBA能夠使其離線。。使部分數(shù)據(jù)不可用,而剩余的部分承諾正常存取。執(zhí)行離線的表空間后備。為了修改或愛護一應用,使它和它的一組表臨時不可用。包含有正在活動的回滾段的表空間不能被離線,僅當回滾段不正在使用時,該表空間才可離線。在數(shù)據(jù)字典中記錄表空間的狀態(tài),在線依舊離線。假如在數(shù)據(jù)庫關(guān)閉時一表空間為離線,那么在下次數(shù)據(jù)庫裝配和重新打開后,它仍舊保持離線。當顯現(xiàn)某些錯誤時,一個表空間可自動地由在線改變?yōu)殡x線。通過使用多個表空間,將不同類型的數(shù)據(jù)分開,更方便DBA來治理數(shù)據(jù)庫。ORACLE數(shù)據(jù)庫中一表空間是由一個或多個物理數(shù)據(jù)文件組成,一個數(shù)據(jù)文件只可與一個表空間想聯(lián)系。當為一表空間建立一數(shù)據(jù)文件時,ORACLE建立該文件,分配指定的磁盤空間容量。在數(shù)據(jù)文件初時建立后,所分配的磁盤不包含任何數(shù)據(jù)。表空間能夠在線或離線。在ORACLE中還承諾單獨數(shù)據(jù)文件在線或離線。段、范疇和數(shù)據(jù)塊ORACLE通過段、范疇和數(shù)據(jù)塊邏輯數(shù)據(jù)結(jié)構(gòu)可更細地操縱磁盤空間的使用。段段(SEGMENT)包含表空間中一種指定類型的邏輯儲備結(jié)構(gòu),是由一組范疇組成。在ORACLE數(shù)據(jù)庫中有幾種類型的段:數(shù)據(jù)段、牽引段、回滾段和臨時段。數(shù)據(jù)段:關(guān)于每一個非集合的表有一數(shù)據(jù)段,表的所有數(shù)據(jù)存放在該段。每一集合有一個數(shù)據(jù)段,集合中每一個表的數(shù)據(jù)儲備在該段中。索引段:每一個索引有一索引段,儲備索引數(shù)據(jù)?;貪L段:是由DBA建立,用于臨時儲備要撤消的信息,這些信息用于生成讀一致性數(shù)據(jù)庫信息、在數(shù)據(jù)庫復原時使用、回滾未提交的事務。臨時段:當一個SQL語句需要臨時工作區(qū)時,由ORACLE建立。當語句執(zhí)行完畢,臨時段的范疇退回給系統(tǒng)。ORACLE對所有段的空間分配,以范疇為單位。范疇一個范疇(EXTENT)是數(shù)據(jù)庫儲備空間分配的一個邏輯單位,它由連續(xù)數(shù)據(jù)塊所組成。每一個段是由一個或多個范疇組成。當一段中間所有空間已完全使用時,ORACLE為該段分配一個新的范疇。為了愛護的目的,在數(shù)據(jù)庫的每一段含有段標題塊(segmentheaderblock)說明段的特點以及該段中的范疇名目。數(shù)據(jù)塊數(shù)據(jù)塊(datablock)是ORACLE治理數(shù)據(jù)文件中儲備空間的單位,為數(shù)據(jù)庫使用的I/O的最小單位,其大小可不同于操作系統(tǒng)的標準I/O塊大小。數(shù)據(jù)塊的格式:公用的變長標題表名目行名目未用空間行數(shù)據(jù)模式和模式對象一個模式(schema)為模式對象(scehmaobject)的一個集合,每一個數(shù)據(jù)庫用戶對應一個模式。模式對象為直截了當引用數(shù)據(jù)庫數(shù)據(jù)的邏輯結(jié)構(gòu),模式對象包含如表、視圖、索引、集合、序列、同義詞、數(shù)據(jù)庫鏈、過程和包等結(jié)構(gòu)。模式對象是邏輯數(shù)據(jù)儲備結(jié)構(gòu),每一種模式對象在磁盤上沒有一個相應文件儲備其信息。一個模式對象邏輯地儲備在數(shù)據(jù)庫的一個表空間中,每一個對象的數(shù)據(jù)物理地包含在表空間的一個或多個數(shù)據(jù)文件中。表表(table)為數(shù)據(jù)庫中數(shù)據(jù)儲備的差不多單位,其數(shù)據(jù)按行、列儲備。每個表具有一表名和列的集合。每一列有一個列名、數(shù)據(jù)類型、寬度或精度、比例。一行是對應單個記錄的列信息的集合。視圖一個視圖(view)是由一個或多個表(或其他視圖)中的數(shù)據(jù)的一種定制的表示,是用一個查詢定義,因此可認為是一個儲備的查詢(storedquery)或是一個虛表(virtualtable)。視圖可在使用表的許多地點使用。由于視圖是由表導出的,視圖和表存在許多類似,視圖象表最多可定義254列。視圖能夠被查詢,而在修改、插入或刪除時具有一定的限制,在視圖上執(zhí)行的全部操作真正地阻礙視圖的差不多表中的數(shù)據(jù),受到差不多表的完整性約束和觸發(fā)器的限制。視圖與表不同,一個視圖不分配任何儲備空間,視圖不真正地包含數(shù)據(jù)。由查詢定義的視圖相應于視圖引用表中的數(shù)據(jù)。視圖只在數(shù)據(jù)字典中儲備其定義。引入視圖有下列好處:。通過限制對表的行預定義集合的存取,為表提供附加的安全性。隱藏數(shù)據(jù)復雜性。。為用戶簡化命令。為差不多表的數(shù)據(jù)提供另一種觀點。??蓪酶綦x差不多表定義的修改。用于不用視圖無法表示的查詢。??捎糜趦Υ鎻碗s查詢。集合集合(cluster)是儲備表數(shù)據(jù)的可選擇的方法。一個集合是一組表,將具有同一公共列值的行儲備在一起,同時它們經(jīng)常一起使用。這些公共列構(gòu)成集合碼。例如:EMP表各DEPT表共享DEPTNO列,因此EMP表和DEPT表可集合在一起,集合碼的列為DEPTNO列,該集合將每個部門的全部職工行各該部門的行物理地儲備在同一數(shù)據(jù)塊中。索引索引(index)是與表和集合相關(guān)的一種選擇結(jié)構(gòu)。索引是為提高數(shù)據(jù)檢索的性能而建立,利用它可快速地確定指定的信息。ORACLE索引為表數(shù)據(jù)提供快速存取路徑。索引適用于一范疇的行查詢或指定行的查詢。索引可建立在一表的一列或多列上,一旦建立,由ORACLE自動愛護和使用,對用戶是完全透亮的。索引是邏輯地和物理地獨立于數(shù)據(jù),它們的建立或刪除對表沒有阻礙,應用可連續(xù)處理。索引數(shù)據(jù)的檢干脆能幾乎保持常數(shù),而當一表上存在許多索引時,修改、刪除和插入操作的性能會下降。索引有唯獨索引各非唯獨索引。唯獨索引保證表中沒有兩行在定義索引的列上具有重復值。ORACLE在唯獨碼上自動地定義唯獨索引實施UNIQUE完整性約束。組合索引是在表的某個列上所建立的一索引。組全索引可加快SELECT語句的檢索速度,在其WHERE子句中可引用組合索引的全部或要緊部分。因此在定義中給出列的次序,將經(jīng)常存取的或選擇最多的列放在首位。在建立索引時,將在表空間自動地建立一索引段,索引段空間分配和保留空間的使用受下列方式操縱:索引段范疇的分配常駐該索引段的儲備參數(shù)操縱。其數(shù)據(jù)塊中未用空間可受該段的PCTFREE參數(shù)設置所操縱。序列生成器序列生成器(sequencegenerator)產(chǎn)生序列號。在多用戶環(huán)境下該序列生成器專門有用,可生成各返回序列號而不需要磁盤I/O或事務封鎖。序列號為ORACLE整數(shù),最多可有38個數(shù)字。一個序列定義指出一樣信息:序列的名字、上升或下降、序列號之間間距和其它信息。對所有序列的確的定義以行儲備在SYSTEM表空間中的數(shù)據(jù)字典表中,因此所有序列定義總是可用。由引用序列號的SQL語句使用序列號,可生成一個新的序列號或使用當前序列號。一旦在用戶會話中的SQL語句生成一序列號,該序列號僅為該會話可用。序列號生成是獨立于表,因此同一序列生成器可用于一個和多個表。所生成序列號可用于生成唯獨的主碼。同義詞一個同義詞(synonym)為任何表、視圖、快照、序列、過程、函數(shù)或包的別名,其定義儲備在數(shù)據(jù)字典中。同義詞因安全性和方便緣故而經(jīng)常使用,可用于:可屏蔽對象的名字及其持有者。為分布式數(shù)據(jù)庫的遠程對象提供位置透亮性。為用戶簡化SQL語句。有兩種同義詞:公用和專用。一個公用同義詞為命名為PUBLIC專門用戶組所持有,可為數(shù)據(jù)庫中每一個用戶所存取。一個專用同義詞是包含在指定用戶的模式中,僅為該用戶和授權(quán)的用戶所使用。雜湊雜湊(hashing)是儲備表數(shù)據(jù)一種可選擇的方法,用以改進數(shù)據(jù)檢索的性能。要使用雜湊,就要建立雜湊集合,將表裝入到該集合。在驃湊集合中的表行依照雜湊函數(shù)的結(jié)果進行物理學儲備和檢索。雜湊函數(shù)用于生成一個數(shù)值的分布,該數(shù)值稱為雜湊值,它是基于指定的集合碼值。程序單元程序單元(programunit)是指儲備過程、函數(shù)和包(PACKAGE)。一個過程和函數(shù),是由SQL語句和PL/SQL語句組合在一起,為執(zhí)行某一個任務的一個可執(zhí)行單位。一個過程或函數(shù)可被建立,在數(shù)據(jù)庫中儲備其編譯形式,可由用戶或數(shù)據(jù)庫應用所執(zhí)行。過程和函數(shù)差別在函數(shù)總返回單個值給調(diào)用者,而過程沒有值返回給調(diào)用者。包提供相關(guān)的過程、函數(shù)、變量和其它包結(jié)構(gòu)封裝起來并存貯在一起的一種方法,承諾治理者和應用開發(fā)者利用該方法組織如此的程序(routine),來提供更多的功能和提高性能。數(shù)據(jù)庫鏈數(shù)據(jù)庫鏈是一個命名的對象,說明從一數(shù)據(jù)庫到另一數(shù)據(jù)庫的一路徑(PATH)。在分布式數(shù)據(jù)庫中,對全局對象名引用時,數(shù)據(jù)庫鏈隱式地使用。三、數(shù)據(jù)庫和實例的啟動和關(guān)閉一個ORACLE數(shù)據(jù)庫沒有必要對所有用戶總是可用,數(shù)據(jù)庫治理員可啟動數(shù)據(jù)庫,以致它被打開。在數(shù)據(jù)庫打開情形下,用戶可存取數(shù)據(jù)庫中的信息。當數(shù)據(jù)庫不使用時,DBA可關(guān)閉它,關(guān)閉后的數(shù)據(jù)庫,用戶不能存取其信息。數(shù)據(jù)庫的啟動和關(guān)閉是專門重要的治理功能,通過以INTERNAL連接到ORACLE的能力來愛護。以INTERNAL連接到ORACLE需要有下列先決條件:該用戶的操作系統(tǒng)賬號具有使用INTERNAL連接的操作系統(tǒng)特權(quán)。對INTERNAL數(shù)據(jù)庫有一口令,該用戶明白其口令。另外:當用戶以INTERNAL連接時,可連接到專用服務器,而且是安全連接。數(shù)據(jù)庫啟動啟動數(shù)據(jù)庫并使它可用有三步操作:啟動一個實例;裝配數(shù)據(jù)庫打開數(shù)據(jù)庫啟動一個實例啟動一實例的處理包含分配一個SGA(數(shù)據(jù)庫信息使用的內(nèi)存共享區(qū))和后臺進程的建立。實例起動的執(zhí)行先于該實例裝配一數(shù)據(jù)庫。假如僅啟動實例,則沒有數(shù)據(jù)庫與內(nèi)儲備結(jié)構(gòu)和進程相聯(lián)系。裝配一數(shù)據(jù)庫裝配數(shù)據(jù)庫是將一數(shù)據(jù)庫與已啟動的實例相聯(lián)。當實例安裝一數(shù)據(jù)庫之后,該數(shù)據(jù)庫保持關(guān)閉,僅DBA可存取。打開一數(shù)據(jù)庫打開一數(shù)據(jù)庫是使數(shù)據(jù)庫能夠進行正常數(shù)據(jù)庫操作的處理。當一數(shù)據(jù)庫打開所有用戶可連接到該數(shù)據(jù)庫用存取其信息。在數(shù)據(jù)庫打開時,在線數(shù)據(jù)文件和在線日志文件也被打開。假如一表空間在上一次數(shù)據(jù)庫關(guān)閉時為離線,在數(shù)據(jù)庫再次打開時,該表空間與它所相聯(lián)的數(shù)據(jù)文件依舊離線的。數(shù)據(jù)庫和實例的關(guān)閉關(guān)閉一實例以及它所連接的數(shù)據(jù)庫也有三步操作:關(guān)閉數(shù)據(jù)庫數(shù)據(jù)庫停止的第一步是關(guān)閉數(shù)據(jù)庫。當數(shù)據(jù)庫關(guān)閉后,所有在SGA中的數(shù)據(jù)庫數(shù)據(jù)和復原數(shù)據(jù)相應地寫入到數(shù)據(jù)文件和日志文件。在這操作之后,所有聯(lián)機數(shù)據(jù)文件和聯(lián)機的日志文件也被關(guān)閉,任何離線表空間中數(shù)據(jù)文件夾是已關(guān)閉的。在數(shù)據(jù)庫關(guān)閉后但還安裝時,操縱文件仍保持打開。卸下數(shù)據(jù)庫停止數(shù)據(jù)庫的第二步是從實例卸下數(shù)據(jù)庫。在數(shù)據(jù)庫卸下后,在運算機內(nèi)存中僅保留實例。在數(shù)據(jù)庫卸下后,數(shù)據(jù)庫的操縱文件也被關(guān)閉。停止實例停止數(shù)據(jù)庫的最后一步是停止實例。當實例停止后,SAG是從內(nèi)存中撤消,后臺進程被中止。初始化參數(shù)文件在啟動一個實例時,ORACLE必須讀入一初始化參數(shù)文件(initializationparameterfile),該參數(shù)文件是一個文本文件,包含有實例配置參數(shù)。這些參數(shù)置成專門值,用于初始ORACLE實例的許多內(nèi)存和進程設置,該參數(shù)文件包含:一個實例所啟動的數(shù)據(jù)庫名字在SGA中儲備結(jié)構(gòu)使用多少內(nèi)存;在填滿在線日志文件后作什么;數(shù)據(jù)庫操縱文件的名字和位置;在數(shù)據(jù)庫中專用回滾段的名字。四、數(shù)據(jù)字典的使用數(shù)據(jù)字典是ORACLE數(shù)據(jù)庫的最重要的部分之一,是由一組只讀的表及其視圖所組成。它提供有關(guān)該數(shù)據(jù)庫的信息,可提供的信息如下:ORACLE用戶的名字;每一個用戶所授的特權(quán)和角色;模式對象的名字(表、視圖、快照、索引、集合、同義詞、序列、過程、函數(shù)、包及觸發(fā)器等);關(guān)于完整性約束的信息;列的缺省值;有關(guān)數(shù)據(jù)庫中對象的空間分布及當前使用情形;審計信息(如誰存取或修改各種對象);其它一樣的數(shù)據(jù)庫信息。可用SQL存取數(shù)據(jù)字典,由于數(shù)據(jù)字典為只讀,承諾查詢。數(shù)據(jù)字典的結(jié)構(gòu)數(shù)據(jù)庫數(shù)據(jù)字典是由差不多表和用戶可存取的視圖組成。差不多表:數(shù)據(jù)字典的基礎是一組差不多表組成,儲備相關(guān)的數(shù)據(jù)庫的信息。這些信息僅由ORACLE讀和寫,它們專門少被ORACLE用戶直截了當存取。用戶可存取視圖:數(shù)據(jù)字典包含用戶可存取視圖,可概括地點便地顯示數(shù)據(jù)字典的差不多表的信息。視圖將差不多表中信息解碼成可用信息。數(shù)據(jù)字典的使用當數(shù)據(jù)庫打開時,數(shù)據(jù)字典總是可用,它駐留在SYSTEM表空間中。數(shù)據(jù)字典包含視圖集,在許多情形下,每一視圖集有三種視圖包含有類似信息,彼此以前綴相區(qū)別,前綴USER、ALL和DBA。前綴為USER的視圖,為用視圖,是在用戶的模式內(nèi)。前綴為ALL的視圖,為擴展的用戶視圖(為用戶可存取的視圖)。前綴為DBA的視圖為DBA的視圖(為全部用戶可存取的視圖)。在數(shù)據(jù)庫中ORACLE還愛護了一組虛表記錄當前數(shù)據(jù)庫的活動,這些表稱為動態(tài)性能表。動態(tài)性能表不是真正的表,許多用戶不能存取,DBA可查詢這些表,能夠建立視圖,給其它用戶授予存取視圖權(quán)。五、事務治理事務一個事務為工作的一個邏輯單位,由一個或多個SQL語句組成。一個事務是一個原子單位,構(gòu)成事務的全部SQL語句的結(jié)果可被全部提交或者全部回滾。一個事務由第一個可執(zhí)行SQL語句開始,以提交或回滾終止,能夠是顯式的,也但是隱式的(執(zhí)行DDL語句)。在執(zhí)行一個SQL語句顯現(xiàn)錯誤時,該語句所有阻礙被回滾,看起來該語句沒有被執(zhí)行一樣,但它可不能引起當前事務先前的工作的丟失。ORACLE的事務治理在ORACLE中一個事務是由一個可執(zhí)行的SQL語句開始,一個可執(zhí)行SQL語句產(chǎn)生對實例的調(diào)用。在事務開始時,被賦給一個可用回滾段,記錄該事務的回滾項。一個事務以下列任何一個顯現(xiàn)而終止。當COMMIT或ROLLBACK(沒有SAVEPOINT子句)語句發(fā)出。一個DDL語句被執(zhí)行。在DDL語句執(zhí)行前、后都隱式地提交。用戶撤消對ORACLE的連接(當前事務提交)。用戶進程專門中止(當前事務回滾)。提交事務提交一事務,立即在事務中由SQL語句所執(zhí)行的改變永久化。在提交前,ORACLE已有下列情形:在SGA的回滾段緩沖區(qū)已生成回滾段記錄,回滾信息包含有所修改值的老值。在SGA的日志緩沖區(qū)已生成日志項。這些改變在事務提交前可進入磁盤。對SGA的數(shù)據(jù)庫緩沖區(qū)已作修改,這些修改在事務真正提交之前可進入磁盤。在事務提交之后,有下列情形:關(guān)于與回滾段相關(guān)的內(nèi)部事務表記錄提交事務,并賦給一個相應的唯獨系統(tǒng)修改號(SCN),記錄在表中。在SGA的日志緩沖區(qū)中日志項由LGWR進程寫入到在線日志文件,這是構(gòu)成提交事務的原子事務。在行上和表上的封鎖被開釋。該事務標志為完成。注意:關(guān)于提交事務的數(shù)據(jù)修改不必由DBWR后臺進程趕忙寫入數(shù)據(jù)文件,可連續(xù)儲備在SGA的數(shù)據(jù)庫緩沖區(qū)中,在最有效時將其寫入數(shù)據(jù)文件?;貪L事務回滾事務的含義是撤消未提交事務中的SQL語句所作的對數(shù)據(jù)修改。ORALCE承諾撤消未提交的整個事務,也承諾撤消部分。在回滾整個事務(沒有引用保留點)時,有下列情形:在事務中所有SQL語句作的全部修改,利用相應的回滾段被撤消。所有數(shù)據(jù)的事務封鎖被開釋。事務終止。當事務回滾到一保留點(具有SAVEPOINT)時,有下列情形:僅在該保留點之后執(zhí)行的語句被撤消。該指定的保留點仍舊被保留,該保留點之后所建立的保留點被刪除。自該保留點之后所獵取的全部表封鎖和行封鎖被開釋,但指定的保留點往常所獵取的全部數(shù)據(jù)封鎖連續(xù)保持。該事務仍可連續(xù)。保留點保留點(savepoint)是在一事務范疇內(nèi)的中間標志,經(jīng)常用于將一個長的事務劃分為小的部分。保留點可標志長事務中的任何點,承諾可回滾該點之后的工作。在應用程序中經(jīng)常使用保留點;例如一過程包含幾個函數(shù),在每個函數(shù)前可建立一個保留點,假如函數(shù)失敗,專門容易返回到每一個函數(shù)開始的情形。在回滾到一個保留點之后,該保持點之后所獲得的數(shù)據(jù)封鎖被開釋。六、數(shù)據(jù)庫觸發(fā)器觸發(fā)器介紹數(shù)據(jù)庫觸發(fā)器(databasetrigger)是儲備在數(shù)據(jù)庫中的過程,當表被修改時它隱式地被激發(fā)(執(zhí)行)。在ORACLE中承諾在對表發(fā)出INSERT、UPDATE或DELETE語句時隱式地執(zhí)行所定義的過程,這些過程稱為數(shù)據(jù)庫觸發(fā)器。觸發(fā)器儲備在數(shù)據(jù)庫中,并與所相關(guān)表分別儲備。觸發(fā)器僅可在表上定義。在許多情形中觸發(fā)器用于提供專門高級的專用數(shù)據(jù)庫治理系統(tǒng),來補充ORACLE的標準功能。觸發(fā)器一樣用于:自動地生成導出的列值;防止無效的事務;實施更復雜的安全性檢查在分布式數(shù)據(jù)庫中實施跨過結(jié)點的引用完整性;實施復雜的事務規(guī)則;提供透亮事件日志;提供高級的審計;愛護同步表復制;收集關(guān)于存取表的統(tǒng)計。注意:數(shù)據(jù)庫觸發(fā)器與SQL*FORMS觸發(fā)器之間的差別。數(shù)據(jù)庫觸發(fā)器是定義在表上,儲備在數(shù)據(jù)庫中,當對表執(zhí)行INSERT、UPDATE或DELETE語句時被激發(fā),不管是誰或哪一應用發(fā)出。而SQL*FORMS觸發(fā)器是SQL*FORM應用的部分,僅當在指定SQL*FORMS應用中執(zhí)行一個指定觸發(fā)器點時才被激發(fā)。觸發(fā)器和說明性完整性約束都可用于約束數(shù)據(jù)的輸入,但它們之間有一定區(qū)別:說明性完整性約束是關(guān)于數(shù)據(jù)庫總是為“真”的語句。一個完整性約束應用于表中已有數(shù)據(jù)和操縱表的任何語句。而觸發(fā)器約束事務不可應用于在定義觸發(fā)器前已裝入的數(shù)據(jù),因此它不能保證表中全部數(shù)據(jù)服從該觸發(fā)器的規(guī)則。觸發(fā)器實施瞬時約束,即在數(shù)據(jù)改變時實施一約束。觸發(fā)器的組成:一個觸發(fā)器有三個差不多部件:觸發(fā)事件或語句、觸發(fā)器的限制、觸發(fā)器動作。觸發(fā)事件或語句:為引起觸發(fā)器激發(fā)的SQL語句,是對指定表INSERT、UPDATE或DELETE語句。觸發(fā)器限制:為一布爾表達式,當觸發(fā)器激發(fā)時該條件必須為TRUE。觸發(fā)器的限制是用WHEN子句來指定。觸發(fā)器的動作:為一個PL/SQL塊(過程),由SQL語句和PL/SQL語句組成。當觸發(fā)語句發(fā)出,觸發(fā)器的限制運算得TRUE時,它被執(zhí)行。在觸發(fā)器動作的語句中,可使用觸發(fā)器的處理的當前行的列值(新值、老值),使用形式為:NEW.列名引用新值OLE.列名引用老值在定義觸發(fā)器時可指定觸發(fā)器動作執(zhí)行次數(shù):受觸發(fā)語句阻礙每一行執(zhí)行一次或是對觸發(fā)語句執(zhí)行一次。對每一觸發(fā)語句可有四種類型觸發(fā)器:行觸發(fā)器:對受觸發(fā)語句所阻礙的每一行,行觸發(fā)器激發(fā)一次。語句觸發(fā)器:該類型觸發(fā)器對觸發(fā)語句執(zhí)行一次,不管其受阻礙行數(shù)。定義觸發(fā)器能夠指定觸發(fā)時刻,指定激發(fā)器動作的執(zhí)行相關(guān)于觸發(fā)語句執(zhí)行之后或之前。BEFORE觸發(fā)器:該觸發(fā)器執(zhí)行觸發(fā)器動作是在觸發(fā)語句執(zhí)行之前。AFTER觸發(fā)器:該觸發(fā)器執(zhí)行觸發(fā)器動作是在觸發(fā)語句執(zhí)行之后。一個觸發(fā)器可處于兩種不同的方式:使能觸發(fā)器和使不能觸發(fā)器。使能觸發(fā)器:只要當觸發(fā)語句發(fā)出,觸發(fā)器限制運算為TRUE,這種類型的觸發(fā)器執(zhí)行其觸發(fā)動作。使不能觸發(fā)器:這種觸發(fā)器即使其觸發(fā)語句被發(fā)出,觸發(fā)器限制運算為TRUE,也不執(zhí)行觸發(fā)器動作。觸發(fā)器的源代碼儲備在數(shù)據(jù)庫中,在第一次執(zhí)行時,觸發(fā)器的源代碼被編譯,儲備在共享池中。假如觸發(fā)器從共享池中擠了,再使用時必須再重新編譯。七、分布處理和分布式數(shù)據(jù)庫簡介一個分布式數(shù)據(jù)庫在用戶面前為單個邏輯數(shù)據(jù)庫,但實際上是由儲備在多臺運算機上的一組數(shù)據(jù)庫組成。在幾臺運算機上的數(shù)據(jù)庫通過網(wǎng)絡可同時修改和存取,每一數(shù)據(jù)庫受它的局部的DBMS操縱。分布式數(shù)據(jù)庫中每一個數(shù)據(jù)庫服務器合作地愛護全局數(shù)據(jù)庫的一致性。在系統(tǒng)中的每一臺運算機稱為結(jié)點。假如一結(jié)點具有治理數(shù)據(jù)庫軟件,該結(jié)點稱為數(shù)據(jù)庫服務器。假如一個結(jié)點為要求服務器的信息的一應用,該結(jié)點稱為客戶。在ORACLE客戶,執(zhí)行數(shù)據(jù)庫應用,可存取數(shù)據(jù)信息和與用戶交互。在服務器,執(zhí)行ORACLE軟件,處理對ORACLE數(shù)據(jù)庫并發(fā)、共享數(shù)據(jù)存取。ORACLE承諾上述兩部分在同一臺運算機上,但當客戶部分和服務器部分是由網(wǎng)連接的不同運算機上時,更有效。分布處理是由多臺處理機分擔單個任務的處理。在ORACLE數(shù)據(jù)庫系統(tǒng)中分布處理的例子如:客戶和服務器是位于網(wǎng)絡連接的不同運算機上。單臺運算機上有多個處理器,不同處理器分別執(zhí)行客戶應用。SQL*NET是ORACLE網(wǎng)絡接口,承諾運行在網(wǎng)絡工作站的ORACLE工具和服務器上,可存取、修改、共享和儲備在其它服務器上的數(shù)據(jù)。SAQL*NET可被認為是網(wǎng)絡通信的程序接口。SQL*NET利用通信協(xié)議和應用程序接口(API)為OARCLE提供一個分布式數(shù)據(jù)庫和分布處理。SQL*NET驅(qū)動器為在數(shù)據(jù)庫服務器上運行的ORACLE進程與ORACLE工具的用戶進程之間提供一個接口。參與分布式數(shù)據(jù)庫的每一服務器是分別地獨立地治理數(shù)據(jù)庫,好 像每一數(shù)據(jù)庫不是網(wǎng)絡化的數(shù)據(jù)庫。每一個數(shù)據(jù)庫獨立地被治理,稱為場地自治性。場地自治性有下列好處:系統(tǒng)的結(jié)點可反映公司的邏輯組織。由局部數(shù)據(jù)庫治理員操縱局部數(shù)據(jù),如此每一個數(shù)據(jù)庫治理員責任域要小一些,可更好治理。只要一個數(shù)據(jù)庫和網(wǎng)絡是可用,那么全局數(shù)據(jù)庫可部分可用??刹荒芤蛞粋€數(shù)據(jù)庫的故障而停止全部操作或引起性能瓶頸。故障復原通常在單個結(jié)點上進行。每個局部數(shù)據(jù)庫存在一個數(shù)據(jù)字典。結(jié)點可獨立地升級軟件??蓮姆植际綌?shù)據(jù)庫的所有結(jié)點存取

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論