Oracle不同數(shù)據(jù)庫間對(duì)比分析腳本
Oracle數(shù)據(jù)庫開發(fā)應(yīng)用中經(jīng)常對(duì)數(shù)據(jù)庫管理員有這樣的需求,對(duì)比兩個(gè)不同實(shí)例間某模式下對(duì)象的差異或者對(duì)比兩個(gè)不同實(shí)例某模式下表定義的差異性,這在涉及到數(shù)據(jù)庫軟件的開發(fā)應(yīng)用中是經(jīng)常遇到的。一般數(shù)據(jù)庫軟件的開發(fā)都是首先在開發(fā)數(shù)據(jù)庫上進(jìn)行,開發(fā)到一定程度后,系統(tǒng)投入運(yùn)行,此時(shí)軟件處于維護(hù)階段。針對(duì)在系統(tǒng)運(yùn)行中遇到的錯(cuò)誤、bug等,還有應(yīng)用系統(tǒng)的升級(jí),經(jīng)常需要調(diào)整后臺(tái)程序,數(shù)據(jù)庫開發(fā)人員經(jīng)常遇到這樣一種尷尬的事情,維護(hù)到一定時(shí)期,開發(fā)庫和運(yùn)行庫之間出現(xiàn)了一些差異,而這些差異又是什么。還有一種情況就是如果應(yīng)用在很多地方同時(shí)使用,每次的后臺(tái)升級(jí),那些數(shù)據(jù)庫作了升級(jí),那些還沒有作升級(jí),如果沒有詳細(xì)記錄的話,也會(huì)造成我們的尷尬事情。
另外,如果要搭建Oracle的高級(jí)表復(fù)制環(huán)境,在規(guī)劃好了復(fù)制的架構(gòu)以及復(fù)制的表后,在正式將需要復(fù)制的表加入到復(fù)制組之前,一個(gè)重要工作就是檢查這些需要復(fù)制的表在主節(jié)點(diǎn)和主定義節(jié)點(diǎn)間的差異性。如果這些表定義間存在任何細(xì)微的差別,如某個(gè)字段在一個(gè)節(jié)點(diǎn)是允許Null,而在另一個(gè)節(jié)點(diǎn)是Not Null,在將表加入到復(fù)制組時(shí)都會(huì)出現(xiàn)這樣的錯(cuò)誤,“ORA-23309 object string.string of type string exists”,其實(shí)造成這個(gè)錯(cuò)誤的原因就是復(fù)制主定義節(jié)點(diǎn)和主節(jié)點(diǎn)之間表的定義存在某些差異,系統(tǒng)認(rèn)為是兩個(gè)不同的表,但是在兩個(gè)數(shù)據(jù)庫中具有同樣的名稱。如果需要復(fù)制的表很多,手工對(duì)比兩個(gè)節(jié)點(diǎn)復(fù)制表之間的差異是需要很大工作量,而且不一定準(zhǔn)確。
業(yè)界有名的數(shù)據(jù)庫軟件輔助產(chǎn)品提供商美國Embarcadero公司(www.embarcadero.com)在其全套數(shù)據(jù)庫解決方案中就相應(yīng)提供了一個(gè)叫Change Manager的產(chǎn)品,該產(chǎn)品一個(gè)很大的用途就是對(duì)比分析不同實(shí)例間的差異。Oracle公司的OEM(oracle enterprise manager)包中也相應(yīng)提供了一個(gè)工具叫做DB-Diff,也用來比較兩個(gè)數(shù)據(jù)庫間的差異。
其實(shí)對(duì)于普通的數(shù)據(jù)庫開發(fā)在某種程度上說根本不需要上面提到的這些工具軟件,況且這些產(chǎn)品不是隨便可以得到并且使用的。針對(duì)上面提到的這些問題,提供了兩個(gè)SQL腳本,可以輕松實(shí)現(xiàn)對(duì)比分析兩個(gè)不同數(shù)據(jù)庫實(shí)例間對(duì)象的差異以及表定義的差異。
一、對(duì)比兩個(gè)不同實(shí)例下某模式中對(duì)象差異
在運(yùn)行下面的腳本之前,必須首先創(chuàng)建當(dāng)然數(shù)據(jù)庫用戶和需要對(duì)比的兩個(gè)實(shí)例間的數(shù)據(jù)庫聯(lián)接。下面是運(yùn)行該腳本的一個(gè)例子。在SQL/PLUS下運(yùn)行該腳本,系統(tǒng)出現(xiàn)如下提示:
對(duì)象屬主(模式): repadmin
第一個(gè)實(shí)例的數(shù)據(jù)庫聯(lián)接名稱 (包括 @):@ora_zs
第一個(gè)實(shí)例的數(shù)據(jù)庫聯(lián)接名稱 (包括 @):@ora_sjjk
[NextPage]
其中程序要求輸入對(duì)象屬主,也就是對(duì)比那個(gè)用戶,這里是repadmin用戶。然后是需要對(duì)比的實(shí)例聯(lián)接名稱,這里是ora_zs和ora_sjjk,最后給出對(duì)比報(bào)告。
附:PL/SQL程序腳本清單:
二、對(duì)比兩個(gè)不同模式下表定義的差異
運(yùn)行方法和前面第一個(gè)腳本一樣,這里不再詳述。下面是一個(gè)運(yùn)行實(shí)例結(jié)果:
對(duì)象屬主(模式): db_zgxt
第一個(gè)實(shí)例的數(shù)據(jù)庫聯(lián)接名稱 (包括 @):@ora_cx
第一個(gè)實(shí)例的數(shù)據(jù)庫聯(lián)接名稱 (包括 @):@ora_zs
上一頁
相關(guān)文章
Win Oracle 監(jiān)聽文件配置參考代碼實(shí)例
這篇文章主要介紹了Win Oracle 監(jiān)聽文件配置參考代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10
Oracle下的Java分頁功能_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
分頁的時(shí)候返回的不僅包括查詢的結(jié)果集(List),而且還包括總的頁數(shù)(pageNum)、當(dāng)前第幾頁(pageNo)等等信息,所以我們封裝一個(gè)查詢結(jié)果PageModel類,具體實(shí)現(xiàn)代碼,大家參考下本文2017-08-08
oracle實(shí)現(xiàn)一對(duì)多數(shù)據(jù)分頁查詢篩選示例代碼
這篇文章主要給大家介紹了關(guān)于oracle實(shí)現(xiàn)一對(duì)多數(shù)據(jù)分頁查詢篩選的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11
通過實(shí)例了解Oracle序列Sequence使用方法
這篇文章主要介紹了通過實(shí)例了解Oracle序列Sequence使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
Oracle?11g+windows?環(huán)境下Ecology7系統(tǒng)安裝過程
這篇文章主要介紹了Oracle?11g+windows?環(huán)境下Ecology7系統(tǒng)安裝,安裝步驟是以管理員模式運(yùn)行Oracle setup.exe文件,根據(jù)提示安裝Oracle,創(chuàng)建數(shù)據(jù)庫,注意修改連接數(shù),本文給大家詳細(xì)講解,需要的朋友可以參考下2022-10-10
Oracle數(shù)據(jù)庫批量變更字段類型的實(shí)現(xiàn)步驟
我有個(gè)項(xiàng)目使用Oracle數(shù)據(jù)庫,運(yùn)行幾年后數(shù)據(jù)量較大,需要對(duì)數(shù)據(jù)庫做一次優(yōu)化,其中有些字段類型類型需要調(diào)整,這里分享一下實(shí)現(xiàn)步驟,感興趣的朋友可以參考下2024-02-02
淺談PL/SQL批處理語句:BULK COLLECT與FORALL對(duì)優(yōu)化做出的貢獻(xiàn)
本篇文章小編為大家介紹一下,淺談PL/SQL批處理語句:BULK COLLECT與FORALL對(duì)優(yōu)化做出的貢獻(xiàn)。有需要的朋友可以參考一下2013-04-04

