免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

oracle怎么降級 oracle 減

如何降低Oracle表的高水位

1. 執(zhí)行表重建指令 alter table table_name move(驗證不可行,不降低水位線,但可釋放表空間)

10余年專注成都網(wǎng)站制作,企業(yè)網(wǎng)站建設,個人網(wǎng)站制作服務,為大家分享網(wǎng)站制作知識、方案,網(wǎng)站設計流程、步驟,成功服務上千家企業(yè)。為您提供網(wǎng)站建設,網(wǎng)站制作,網(wǎng)頁設計及定制高端網(wǎng)站建設服務,專注于企業(yè)網(wǎng)站建設,高端網(wǎng)頁制作,對成都發(fā)電機回收等多個領域,擁有豐富的網(wǎng)站營銷經(jīng)驗。

當你創(chuàng)建了一個對象如表以后,不管你有沒有插入數(shù)據(jù),它都會占用一些塊,ORACLE也會給它分配必要的空間.同樣,用ALTER TABLE MOVE釋放自由空間后,還是保留了一些空間給這個表.

ALTER TABLE ... MOVE 后面不跟參數(shù)也行,不跟參數(shù)表還是在原來的表空間,Move后記住重建索引.

查詢失效索引語句:select index_name,table_name,tablespace_name,status From dba_indexes Where owner='HNUNICOM' And status'VALID';

重建索引語句:alter index INDEX_NAME rebuild tablespace TABLESPACE_NAME;

如果以后還要繼續(xù)向這個表增加數(shù)據(jù),沒有必要move,只是釋放出來的空間,只能這個表用,其他的表或者segment無法使用該空間。

2. 執(zhí)行alter table table_name shrink space;(已經(jīng)驗證成功,推薦使用,可釋放數(shù)據(jù)庫和磁盤空間空間,大表可同時降低表自身和表空間的高水位線,小表則只可以降低表自身的高水位線,原因不詳)

注意,此命令為Oracle 10g新增功能,執(zhí)行該指令之前必須允許行移動 alter table table_name enable row movement;

3. 復制要保留的數(shù)據(jù)到臨時表t,drop原表,然后rename臨時表t為原表(未驗證

4. 用EXP導出后,刪除原表/表空間,之后用IMP重新導入(驗證成功)

5. Alter table table_name deallocate unused(驗證不可行,不降低水位線)

注:這證明,DEALLOCATE UNUSED為釋放HWM上面的未使用空間,但是并不會釋放HWM下面的自由空間,也不會移動HWM的位置.

6. 盡量使用truncate(驗證不可行,不降低水位線,可釋放數(shù)據(jù)庫空間,但truncate后表默認空間大小為刪除前的空間大小,如想釋放計算機磁盤空間,需要用方法2壓縮)

oracle已提交的數(shù)據(jù)怎么回滾

1、首先oracle已提交的數(shù)據(jù)是可以使用閃回功能來找回數(shù)據(jù)的。

2、其次要先確定提交的數(shù)據(jù)的大體時間。

3、最后點擊閃回按鍵,選擇重新執(zhí)行,就可以選擇提交的數(shù)據(jù)信息進行閃回了。

如何升級oracle版本

本文檔旨在提供指南和核對清單,用于將之前升級的數(shù)據(jù)庫從Oracle12c降級回以前的版本:11.2.0.3,11.2.0.2,11.1.0.7必須加以說明的是,將數(shù)據(jù)庫實例從當前版本降級到升級前的版本時,數(shù)據(jù)庫不會返回到升級前的完全相同狀態(tài)。根據(jù)所涉及的版本,升級過程會進行不可逆的更改。用戶使用降級過程可以打開和訪問以前版本的數(shù)據(jù)庫實例。這通常便已足夠。可能需要采取其他更正操作(例如卸載/重新安裝或重新升級到當前補丁集級別來解決降級后的遺留問題。如果目標是讓實例返回與升級前完全相同的狀態(tài),則還應使用包括完全恢復到升級前狀態(tài)在內的其他過程。本文中討論的過程是基于腳本的降級。本文不介紹使用導出/導入、數(shù)據(jù)泵或其他方法將數(shù)據(jù)從一個版本移動到另一個版本。您所降級到的版本的Oracle二進制文件,在開始降級過程之前應該在服務器上可用/已安裝。如果您卸載了要降級到的Oracle可執(zhí)行文件,請重新安裝Oracle二進制文件到正確的版本/補丁程序級別以降級。此過程旨在降級已成功升級到12c的數(shù)據(jù)庫,并非用于從失敗的升級退回。您只能降級到升級前所用的版本和補丁程序級別。直接升級可以在版本10.2.0.5、11.1.0.7或版本11.2.0.2及更高版本上執(zhí)行。可以對這些版本中除10.2.0.5之外的版本進行降級。例如,如果通過應用中間補丁程序11.1.0.7從Oracle11.1.0.6升級到Oracle12c(12.1.0),則不能降級到Oracle11.1.0.6。降級只能對直接升級版本執(zhí)行。例外:雖然可以對10.2.0.5直接升級,但降級不適用于10.2.0.5。這是因為在升級過程中,compatible參數(shù)已設置為最低11.0.0。這使得無法降級到10.2.0.5。可以降級的版本為11.1.0.7、11.2.0.2、11.2.0.3或更高版本。如果有任何補丁程序應用到了從升級后的主目錄運行的源數(shù)據(jù)庫,則需要先回退,然后才能開始降級過程。卸載和回退補丁程序的步驟記錄在所涉及補丁程序的自述文件中。未能卸載和回退補丁程序可能會導致無法降級,包括無法重新驗證字典對象。Exadata捆綁補丁程序示例,其過程為:卸載補丁程序示例:$opatchauto/u01/app/oracle/patches/14103267-rollback回退任何在補丁程序應用過程中應用的SQL:示例:SQL@rdbms/admin/catbundle_EXA__ROLLBACK.sql,用于回退SQL更改。解決方案降級前步驟-XMLDB組件在12c中是必需的。在升級到12c期間,將安裝XMLDB組件(如果未安裝)。從12c降級將刪除安裝的XDB組件-EnterpriseManager不支持降級。在降級之前,請重新配置OracleEM控件。請參閱OracleDatabaseUpgradeGuide12cRelease1(12.1)E17642-106DowngradingOracleDatabasetoanEarlierRelease6.6.5RestoringOracleEnterpriseManagerafterDowngradingOracleDatabase-升級到12c期間,將刪除DatabaseControl資料檔案庫。降級之后,請重新配置DBControl。Note870877.1HowToSaveOracleEnterpriseManagerDatabaseControlDataBeforeUpgradingTheSingleInstanceDatabaseToOtherRelease?Note876353.1HowToRestoreTheOracleEnterpriseManagerDataToDowngradeTheSingleInstanceDatabaseToPrevious/SourceRelease?-compatible參數(shù)不能已經(jīng)更改到12.1.0。-禁用DataVault(如果已啟用)。Note803948.1HowToUninstallOrReinstallDatabaseVaultin11g(UNIX)Note453902.1EnablingandDisablingOracleDatabaseVaultinWINDOWS-如果數(shù)據(jù)庫使用OracleLabelSecurity,則在新OracleDatabase12cOracle主目錄中運行OracleLabelSecurity(OLS)預處理降級olspredowngrade.sql腳本(在$ORACLE_HOME/rdbms/admin上提供)。-時區(qū)版本應相同。-取消設置并指向12c主目錄的ORA_TZFILE(如果已設置)。-如果數(shù)據(jù)庫上有OracleApplicationExpress,則必須將apxrelod.sql文件從OracleDatabase12c$ORACLE_HOME/apex/目錄復制到Oracle主目錄之外的目錄,例如系統(tǒng)上的臨時目錄以稍后執(zhí)行。-如果基于固定對象創(chuàng)建了對象,則刪除這些對象以避免可能的ORA-00600錯誤。您可以在降級之后重新創(chuàng)建這些對象。-如果降級集群數(shù)據(jù)庫,則徹底關閉實例并將CLUSTER_DATABASE初始化參數(shù)更改為FALSE。降級之后,必須將此參數(shù)設置回TRUE。滿足以上先決條件之后,可以繼續(xù)進行降級。數(shù)據(jù)庫的降級步驟1)確保所有數(shù)據(jù)庫組件有效。只能從成功升級的數(shù)據(jù)庫執(zhí)行降級。要驗證數(shù)據(jù)庫組件狀態(tài),請執(zhí)行以下查詢以SYS用戶身份連接到數(shù)據(jù)庫colcomp_idformata10colcomp_nameformata30colversionformata10colstatusformata8selectsubstr(comp_id,1,15)comp_id,substr(comp_name,1,30)comp_name,substr(version,1,10)version,statusfromdba_registry2)驗證沒有屬于sys/system的無效對象selectowner,count(object_name)"Invalidobjectcount"fromdba_objectswherestatus!='VALID'andownerin('SYS','SYSTEM')groupbyowner;如果計數(shù)為零,則可以繼續(xù)降級。如果有無效對象,則執(zhí)行utlrp.sql多次,如果對象無法解析為有效狀態(tài),則不能繼續(xù)降級。建立SR或在DBA社區(qū)上發(fā)帖以尋求幫助。或者,對于1和2,運行以下腳本:Note556610.1ScripttoCollectDBUpgrade/MigrateDiagnosticInformation(dbupgdiag.sql)3)關閉數(shù)據(jù)庫Shutdownimmediate4)對12c數(shù)據(jù)庫做備份5)以降級模式啟動數(shù)據(jù)庫Startupdowngrade;6)執(zhí)行降級腳本SqlSpooldowngrade.logSql@$ORACLE_HOME/rdbms/admin/catdwgrd.sql注:$ORACLE_HOME應指向12c主目錄catdwgrd.sql腳本將數(shù)據(jù)庫中的所有組件降級到支持的主版本或補丁集版本(您最初升級時的版本)SqlspooloffSqlshutdownimmediateExitSQLPlusSqlexit;7)如果操作系統(tǒng)為LINUX/UNIX:將以下環(huán)境變量更改為要降級到的源數(shù)據(jù)庫:ORACLE_HOMEPATH編輯/etc/oratabor/var/opt/oracle/oratab以更改將數(shù)據(jù)庫映射到源數(shù)據(jù)庫Oracle主目錄如果操作系統(tǒng)是Windows,則完成以下步驟:a.停止所有Oracle服務,包括OracleDatabase12c數(shù)據(jù)庫的OracleServiceSIDOracle服務,其中SID是實例名稱。例如,如果SID為ORCL,則在命令行提示符中輸入以下內容:C:\NETSTOPOracleServiceORCLb.在命令提示符下,通過運行ORADIM命令刪除Oracle服務。如果出現(xiàn)提示,則輸入此Windows系統(tǒng)上活動標準用戶帳戶的口令。例如,如果SID為ORCL,則輸入以下命令:C:\ORADIM-DELETE-SIDORCLc.在命令提示符下,使用ORADIM命令創(chuàng)建要降級的數(shù)據(jù)庫的Oracle服務。C:\ORADIM-NEW-SIDSID-INTPWDPASSWORD-MAXUSERSUSERS-STARTMODEAUTO-PFILEORACLE_HOME\DATABASE\INITSID.ORA8)還原配置文件將配置文件(口令文件、參數(shù)文件等)還原到降級版本的ORACLE_HOME。9)如果這是OracleRAC數(shù)據(jù)庫,則執(zhí)行以下命令以將數(shù)據(jù)庫修改為單實例模式:SETCLUSTER_DATABASE=FALSE10)從降級版本$ORACLE_HOME/rdbms/admin目錄執(zhí)行catrelod腳本。啟動sqlplus,以具有sysdba權限的用戶SYS身份連接到數(shù)據(jù)庫實例,然后以升級模式啟動數(shù)據(jù)庫::cd$ORACLE_HOME/rdbms/admin:sqlplussqlconnectsysassysdbasqlstartupupgradesqlspoolcatrelod.logsql@?/rdbms/admin/catrelod.sqlsqlspooloffcatrelod.sql腳本在降級的數(shù)據(jù)庫中重新加載各個數(shù)據(jù)庫組件的合適版本。11)運行utlrp.sql腳本:SQL@utlrp.sqlSqlexit;utlrp.sql腳本重新編譯先前處于INVALID狀態(tài)的所有現(xiàn)有PL/SQL模塊,例如package、procedure、type等。12)檢查已降級數(shù)據(jù)庫的狀態(tài):Note556610.1ScripttoCollectDBUpgrade/MigrateDiagnosticInformation(dbupgdiag.sql)此sql腳本是一組查詢語句,用于提供用戶友好的輸出,以在升級前后診斷數(shù)據(jù)庫的狀態(tài)。腳本將創(chuàng)建名為db_upg_diag__.log的文件。13)降級之后,可能在sys用戶下發(fā)現(xiàn)無效的QT視圖。這是因為視圖已從基表中選擇了錯誤的列。您需要重新創(chuàng)建這些視圖。請參閱說明:Note1520209.1QT_*BUFERViewsInvalidafterdowngradefrom12C降級后步驟:1)如果您是降級到OracleDatabase11g版本1(11.1.0.7)并且數(shù)據(jù)庫中有OracleApplicationExpress,則轉到您將apxrelod.sql腳本復制到的目錄(在降級前步驟中)。運行apxrelod.sql腳本以手動重新加載OracleApplicationExpress:SQL@apxrelod.sql運行apxrelod.sql腳本以避免程序包APEX_030200.WWV_FLOW_HELP由于以下錯誤而成為INVALID狀態(tài):PLS-00201:identifier'CTX_DDL'mustbedeclared2)如果數(shù)據(jù)庫中啟用了OracleLabelSecurity,則執(zhí)行以下腳本a.從OracleDatabase12c的Oracle主目錄下將olstrig.sql腳本復制到要將數(shù)據(jù)庫降級到的版本的Oracle主目錄。b.從降級到的版本的Oracle主目錄,運行olstrig.sql以在表上使用OracleLabelSecurity策略重新創(chuàng)建DML觸發(fā)器:SQL@olstrig.sql3)如果降級集群數(shù)據(jù)庫,則必須運行以下命令以降級OracleClusterwaredatabase配置:$srvctldowngradedatabase-ddb-unique-name-ooraclehome-tto_version其中db-unique-name是數(shù)據(jù)庫名稱(而非實例名稱),oraclehome是已降級數(shù)據(jù)庫的舊Oracle主目錄的位置,to_version是數(shù)據(jù)庫所降級到的數(shù)據(jù)庫版本

oracle 11g 并行操作 降級 為什么

并行概念

并行執(zhí)行(parallel execution)是Oracle企業(yè)版才有的特性(標準版中沒有這個特性),指能夠將一個大型串行任務(任何DML,或者一般的DDL)物理地劃分為多個較小的部分,這些較小的部分可以同時得到處理。

并行包括:

并行查詢:這是指能使用多個操作系統(tǒng)進程或線程來執(zhí)行一個查詢。Oracle會發(fā)現(xiàn)能并行執(zhí)行的操作(如全表掃描或大規(guī)模排序),并創(chuàng)建一個查詢計劃來實現(xiàn))。

并行DML(PDML):這在本質上與并行查詢很相似,但是PDML主要是使用并行處理來執(zhí)行修改(INSERT、UPDATE、DELETE和MERGE)。

并行DDL:并行DDL是指Oracle能并行地執(zhí)行大規(guī)模的DDL操作。例如,索引重建、創(chuàng)建一個新索引、數(shù)據(jù)加載以及大表的重組等都可以使用并行處理。

并行恢復:這是指數(shù)據(jù)庫能并行地執(zhí)行實例(甚至介質)恢復,以減少從故障恢復所需的時間。

過程并行化:這是指能并行地運行所開發(fā)的代碼。

何時使用并行

在應用并行執(zhí)行之前,需要保證以下兩點成立:

必須有一個非常大的任務,如對50GB數(shù)據(jù)進行全面掃描。

必須有足夠的可用資源(CPU、I/O、內存)。在并行全面掃描50GB數(shù)據(jù)之前,你要確保有足夠的空閑CPU(以容納并行進程),還要有足夠的I/O通道。

如果只有一個小任務(通常OLTP系統(tǒng)中執(zhí)行的查詢就是這種典型的小任務),或者你的可用資源不足(這也是OLTP系統(tǒng)中很典型的情況),其中CPU和I/O資源通常已經(jīng)得到最大限度的使用,那就根本不用考慮并行執(zhí)行。

如果一個任務只需要幾秒(或更短時間)就能串行地完成,引入并行執(zhí)行后,相關的管理開銷可能會讓整個過程花費更長的時間。

舉例如,寫一頁文檔若12個人來寫,需要開會分段等,可能并不如一個人來寫更快。而如果寫1200頁,12個人寫需要的時間只為原來的1/12,就算分配任務可能也就1/12,還是比一個人寫要快多了。

并行查詢

并行查詢允許將一個SQL SELECT語句劃分為多個較小的查詢,每個部分的查詢并發(fā)地運行,然后會將各個部分的結果組合起來,提供最終的答案。

在并行進程和掃描文件之間并不存在1對1映射,可以多個進程掃描同一個文件。

各個并行進程可稱為并行執(zhí)行服務器(parallel execution server),有時也稱為并行查詢(parallel

query,PQ)從屬進程。各個并行執(zhí)行服務器都是單獨的會話,就像是專業(yè)服務器進程一樣連接數(shù)據(jù)庫。每個并行執(zhí)行服務器分別負責掃描表中一個部分(各

個部分都不重疊),匯總其結果子集,將其輸出發(fā)回給協(xié)調服務器(即原始會話的服務器進程),它再將這些子結果匯總為最終答案。

在默認情況下,Oracle是不啟用并行查詢的。啟用并行查詢有多種方法,可以直接在查詢中使用一個提示,或者修改表要求考慮并行執(zhí)行路徑等。

【并行查詢方法】

1)暗示hints式,臨時有效

select /*+parallel(table_name num)*/ count(*) from table_name;

多表關聯(lián)時多表并行:

select /*+parallel(table_name1,num1) parallel(table_name2,num2)*/ count(*) from table_name1, table_name2;

2)alter table對象式,長期有效

alter table table_name parallel num;

3)alter session會話式,會話生命周期有效

alter session force parallel query parallel num;

4)并行DDL式,會話生命周期有效

alter session enable parallel dml;

對于前兩種方式,若省略num則Oracle將自動根據(jù)負載確定并行度。并行度要隨著系統(tǒng)上工作負載的增減而變化。如果有充足的空閑資源,并行度會

上升;如果可用資源有限,并行度則會下降。這樣就不會為機器強加一個固定的并行度。利用這種方法,允許Oracle動態(tài)地增加或減少查詢所需的并發(fā)資源

量。

【查看默認并行數(shù)】

1)確定會話SID

select sid from v$mystat where rownum = 1;

2)在其他會話中查詢

select sid,qcsid,server#,degree from v$px_session where qcsid = num;

一般而言,如果能訪問盡可能多的資源(CPU、內存和I/O),并行執(zhí)行就能最好地發(fā)揮作用。但這并不是說如果整個數(shù)據(jù)集都在一個磁盤上,就從并行

查詢得不到任何好處。不過如果整個數(shù)據(jù)集都在一個磁盤上,可能確實不如使用多個磁盤那樣能有更多收獲。即使使用一個磁盤,在響應時間上也可能可以得到一定

的速度提升。原因在于:給定的一個并行執(zhí)行服務器在統(tǒng)計行時并不讀取這些行,反之亦然。所以,與執(zhí)行串行相比,兩個并行執(zhí)行服務器可以在更短的時間內完成

所有行的統(tǒng)計。

數(shù)據(jù)分布在多個物理設備上可以提高I/O,如表分區(qū)、跨磁盤等。

在Oracle 11g Release2及以上版本中,引入了一項新功能來限制資源過度使用:并行語句排除(Parallel

Statement

Queuing,PSQ)。使用PSQ時,數(shù)據(jù)庫會限制并發(fā)執(zhí)行的并行查詢數(shù),并把更多的并行請求放在一個執(zhí)行隊列中。CPU資源用盡時數(shù)據(jù)庫會阻止新的

請求變?yōu)榛顒訝顟B(tài)。這些請求并沒有失敗,它們只是會延遲開始,也就是說它們將排隊。資源可用時,數(shù)據(jù)庫就會開始執(zhí)行隊列中的查詢。

并行DML

Oracle文檔將并行DML(PDML)一詞的范圍限制為只包括INSERT、UPDATE、DELETE和MERGE(不像平常的DML那樣還

包括SELECT)。在PDML期間,Oracle可以使用多個并行執(zhí)行服務器來執(zhí)行INSERT、UPDATE、DELETE或MERGE,而不是只利

用一個串行進程。在一個有充足I/O帶寬的多CPU主機上,對于大規(guī)模的DML操作,可能會得到很大的速度提升。

不過,不能把PDML當成提高OLTP應用速度的一個特性。因為并行操作設計為要充分、完全地利用一臺機器上的所有資源。通過這種設計,一個用戶可

以完全使用機器上的所有磁盤、CPU和內存。在某些數(shù)據(jù)倉庫中(有大量數(shù)據(jù),而用戶很少),這可能正是你想要的。而在一個OLTP系統(tǒng)中(大量用戶都在做

很短、很快的事務),可能就不能希望如此了,你不想讓用戶能夠完全占用機器資源。

類似于Oracle執(zhí)行的分布式查詢,PDML操作采用同樣的方式執(zhí)行,即每個并行執(zhí)行服務器相當于一個單獨數(shù)據(jù)庫實例中的一個進程。這些事務都結束后,會執(zhí)行一個相當于快速2PC的過程來提交這些單獨的獨立事務。這些事務要么都由PDML協(xié)調會話提交,要么無一提交。

由于PDML采用的一種偽分布式的實現(xiàn),因此存在一些限制:

PDML操作期間不支持觸發(fā)器。這是一個很合理的限制,因為觸發(fā)器可能會向更新增加大量開銷,而你使用PDML的本來目的是為了更快一些,這兩方面是矛盾的,不能放在一起。

PDML期間,不支持某些聲明方式的引用完整性約束,因為表中的每一片(部分)會在單獨的會話中作為單獨的事務進行修改。例如,PDML操作不支持自引用完整性。如果真的支持自引用完整性,可能會出現(xiàn)死鎖和其他鎖定問題。

在提交或回滾之前,不能訪問用PDML修改的表。

PDML不支持高級復制(因為復制特性的實現(xiàn)要基于觸發(fā)器)。

不支持延遲約束(也就是說,采用延遲模式的約束)。

如果表是分區(qū)的,PDML只可能在有位圖索引或LOB列的表上執(zhí)行,而且并行度取決于分區(qū)數(shù)。在這種情況下,無法在分區(qū)內并行執(zhí)行一個操作,因為每個分區(qū)只有一個并行執(zhí)行服務器來處理。

執(zhí)行PDML時不支持分布式事務。

PDML不支持聚簇表。

并行DDL

從維護的觀點看,以及從管理的角度來說,并行DDL才是Oracle中并行執(zhí)行最突出的優(yōu)點。如果認為并行查詢主要是為最終用戶設計的,那么并行

DDL則是為DBA/開發(fā)人員設計的。如果沒有并行執(zhí)行,DBA將很難真正充分利用硬件的全部能力。但如果利用并行執(zhí)行,則完全可以做到。以下SQL

DDL命令允許“并行化”:

CREATE INDEX:多個并行執(zhí)行服務器可以掃描表、對數(shù)據(jù)排序,并把有序的段寫出到索引結構。

CREATE TABLE AS SELECT:執(zhí)行SELECT的查詢可以使用并行查詢來執(zhí)行,表加載本身可以并行完成。

ALTER INDEX REBUILD:索引結構可以并行重建。

ALTER TABLE MOVE:表可以并行移動。

ALTER TABLE SPLIT|COALESCE PARTITION:單個表分區(qū)可以并行地分解或合并。

ALTER INDEX SPLIT PARTITION:索引分區(qū)可以并行地分解。

前4個命令還適用于單個的表/索引分區(qū),也就是說,可以并行地MOVE一個表的單個分區(qū)。

并行DDL和使用外部表的數(shù)據(jù)加載

利用并行DDL,再加上外部表,就能通過一個簡單的CREATE TABLE AS SELECT or INSERT /*+ APPEND

*/來實現(xiàn)并行直接路徑加載。不用再編寫腳本,不必再分解文件,也不用協(xié)調要運行的N個腳本。簡單地說,通過結合并行DDL和外部表,不僅提供了純粹的易

用性,而且全無性能損失。

并行DDL和區(qū)段截斷

并行DDL依賴于直接路徑操作。也就是說,數(shù)據(jù)不傳遞到緩沖區(qū)緩存以便以后寫出;而是由一個操作(如CREATE TABLE AS

SELECT)來創(chuàng)建新的區(qū)段,并直接寫入這些區(qū)段,數(shù)據(jù)直接從查詢寫到磁盤(放在這些新分配的區(qū)段中)。每個并行執(zhí)行服務器執(zhí)行自己的部分CREATE

TABLE AS SELECT工作,并且都會寫至自己的區(qū)段。INSERT /*+ APPEND

*/(直接路徑插入)會在一個段的HWM“之上“寫,每個并行執(zhí)行服務器再寫至其自己的一組區(qū)段,而不會與其他并行執(zhí)行服務器共享。因此,如果執(zhí)行一個并

行CREATE TABLE AS

SELECT,并使用4個并行執(zhí)行服務器來創(chuàng)建表,就至少有4個分區(qū),可能還會更多。每個并行執(zhí)行服務器會分配其自己的區(qū)段,向其寫入,等填滿時,再分配

另一個新的區(qū)段,并行執(zhí)行服務器不會使用由其他并行執(zhí)行服務器非品牌的區(qū)段。

在數(shù)據(jù)倉庫環(huán)境中,執(zhí)行一個大規(guī)模的加載之后,這可能導致“過渡浪費“。假設你想加載1,010MB的數(shù)據(jù)(大約1GB),而且正在使用一個有

100MB區(qū)段的表空間,你決定使用10個并行執(zhí)行服務器來加載這個數(shù)據(jù)。每個并行執(zhí)行服務器先分配其自己的100MB區(qū)段(總共會有10個100MB的

區(qū)段),并在其中填入數(shù)據(jù)。由于每個并行執(zhí)行服務器都要加載101MB的數(shù)據(jù),所以它會填滿第一個區(qū)段,然后再繼續(xù)分配另一個100MB的區(qū)段,但實際上

只會使用這個區(qū)段中1MB的空間。現(xiàn)在就有了20區(qū)段,其中10個是滿的,另外10個則不同,這10個區(qū)段中都各有1MB的數(shù)據(jù),因此,總共會有

990MB的空間是”已分配但未使用的“。下一次加載是可以使用這個空間,但是對現(xiàn)在來說,你就有了990MB的死空間。此時區(qū)段截斷(extend

trimming)就能派上用場了。Oracle會試圖取每個并行執(zhí)行服務器的最后一個區(qū)段,并將其”截斷為“可能的最小大小。

區(qū)段截斷和字典管理表空間

如果使用傳統(tǒng)的字典管理表空間,Oracle可以把只包含1MB數(shù)據(jù)的各個100MB區(qū)段轉變或1MB的區(qū)段。遺憾的是,(在字典管理的表空間中)

這會留下10個不連續(xù)的99MB空閑區(qū)段,因為你的分配機制采用的是100MB區(qū)段,所以這990MB空間就會用不上!下一次分配100MB時,往往無法

使用現(xiàn)有的這些空間,因為現(xiàn)在的情況是:有99MB的空閑空間,接下來是1MB的已分配空間,然后又是99MB空閑空間,依此類推。

區(qū)段截斷和本地管理表空間

本地管理表空間有兩種類型:UNIFORM SIZE 和AUTOALLOCATE,UNIFORM

SIZE是指表空間中的每個區(qū)段大小總是完全相同;AUTOALLOCATE則表示Oracle會使用一種內部算法來確定每個區(qū)段應該是多大。這些方法都

能很好地解決上述問題,不過,這兩種方法的解決策略截然不同。

在字典管理的表空間中,如果請求一個100MB區(qū)段,倘若Oracle只找到了99MB的自由區(qū)段,請求還是會失敗。與字典管理表空間不同,有AUTOALLOCATE區(qū)段的本地管理表空間可以更為靈活。為了試圖使用所有空閑空間,它可以減小所請求的空間大小。

隨著使用并行直接路徑操作向表UNIFORM_TEST加載越來越多的數(shù)據(jù),過一段時間后,空間利用情況會變得越來越糟糕。對此,我們可能希望使用

一個更小的統(tǒng)一區(qū)段大小,或者使用AUTOALLOCATE。一段時間后,AUTOALLOCATE也可能生成更多的區(qū)段,但是由于會發(fā)生區(qū)段截斷,所以

空間利用情況要好得多。

Oracle數(shù)據(jù)庫如何從11.2 降級至之前的版本

重新安裝,將11.2中的數(shù)據(jù)導入到新安裝的數(shù)據(jù)庫中。沒有其他辦法。

分享標題:oracle怎么降級 oracle 減
分享網(wǎng)址:http://m.newbst.com/article0/hjhsio.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設商城網(wǎng)站移動網(wǎng)站建設手機網(wǎng)站建設用戶體驗外貿網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿網(wǎng)站建設