1.所謂的物化視圖,
成都創(chuàng)新互聯(lián)專注于伊金霍洛企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站設(shè)計(jì),成都商城網(wǎng)站開發(fā)。伊金霍洛網(wǎng)站建設(shè)公司,為伊金霍洛等地區(qū)提供建站服務(wù)。全流程定制網(wǎng)站設(shè)計(jì),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
2手工寫TRIGER,
3.通過ORACLE的CDC工具可以實(shí)現(xiàn)同步或者異步的表的變化。
4。關(guān)于你說的表三和表一表二之間同步,俺沒有明白。猜測(cè)是對(duì)表一表二做ETL,然后放到表三中。只對(duì)增量進(jìn)行抽取和轉(zhuǎn)換。如果是這樣。通過上面的一二三步之一后。對(duì)增量進(jìn)行抽取和轉(zhuǎn)換。
ETL是個(gè)比較復(fù)雜也好玩的東西。多種方式可以實(shí)現(xiàn),但是相互影響較大。容易顧此失彼。比如說管理和性能的平衡問題就是其中之一。
為方便完成指定數(shù)據(jù)表的同步操作,可以采用dblink與merge結(jié)合的方法完成。
操作環(huán)境: 此數(shù)據(jù)庫服務(wù)器ip為192.168.196.76,有center與branch兩個(gè)庫,一般需要將center的表數(shù)據(jù)同步到branch,center為源庫,branch為目標(biāo)庫!
兩個(gè)一樣的oracle ,定期同步,說白了就是主備用數(shù)據(jù)庫數(shù)據(jù)同步的問題;
如果數(shù)據(jù)庫A和數(shù)據(jù)庫B是建立在兩臺(tái)獨(dú)立的數(shù)據(jù)庫服務(wù)器上,那么采用dblink方式是一種可行的方式,
第一種方式:前提是數(shù)據(jù)庫A和數(shù)據(jù)庫B本地網(wǎng)是24小時(shí)互通的同時(shí)對(duì)數(shù)據(jù)同步實(shí)時(shí)性有比較高的要求,那么可以建立DBLINK,在兩個(gè)庫都建觸發(fā)器,不管當(dāng)前在哪個(gè)庫發(fā)生數(shù)據(jù)更新的時(shí)候?qū)崟r(shí)同步數(shù)據(jù)到目標(biāo)數(shù)據(jù)庫;
第二種方式:如果數(shù)據(jù)同步的實(shí)時(shí)性要求不高,則可以通過定制存儲(chǔ)過程的方式(給兩個(gè)庫的數(shù)據(jù)表加時(shí)間戳或者更新標(biāo)志,)定時(shí)同步數(shù)據(jù);
第三種方式:通過給兩個(gè)數(shù)據(jù)庫的數(shù)據(jù)表加更新標(biāo)志字段,以第一種方式為主以滿足實(shí)時(shí)性的要求,以第二種方式為輔彌補(bǔ)可能存在的觸發(fā)器執(zhí)行更新未成功的情況。
以上的方案都是從數(shù)據(jù)層面所做的處理,對(duì)于數(shù)據(jù)實(shí)時(shí)同步還是會(huì)存在一定的風(fēng)險(xiǎn),那么雙機(jī)熱備應(yīng)該說是最好的選擇了。
datagurd:
主要備庫的方式,就是數(shù)據(jù)庫對(duì)數(shù)據(jù)庫的備份方式,主要是解決容災(zāi)的。
流復(fù)制:
主要是利用oracle的歸檔日志,進(jìn)行增量備份來實(shí)現(xiàn)的,不僅可以配置只復(fù)制某些表,還可以配置僅復(fù)制某些表上的ddl或dml。可以復(fù)制到表,用戶,數(shù)據(jù)庫級(jí)別。
高級(jí)復(fù)制:
主要是基于觸發(fā)器的原理來觸發(fā)數(shù)據(jù)同步的,因此,高級(jí)復(fù)制無法實(shí)現(xiàn)用戶,數(shù)據(jù)庫級(jí)別的對(duì)象復(fù)制,只能做些表、索引和存儲(chǔ)過程的復(fù)制。
一、第一套方案
1、用新的建庫腳本創(chuàng)建一套新的數(shù)據(jù)庫,結(jié)構(gòu)和類型都是新的;
2、用數(shù)據(jù)導(dǎo)入工具,將原數(shù)據(jù)庫的數(shù)據(jù)導(dǎo)入到新的數(shù)控里面;
二、第二套方案
1、用新的建庫腳本創(chuàng)建一套新的數(shù)據(jù)庫,結(jié)構(gòu)和類型都是新的;
2、用數(shù)據(jù)庫結(jié)構(gòu)同步工具,將老的數(shù)據(jù)庫結(jié)構(gòu)更新同步到新建的數(shù)據(jù)庫上面;
兩套方案肯定都可行,主要在工作量和工作效率上面區(qū)別太大,導(dǎo)數(shù)據(jù)需要工具,可以用Sqlserver提供的DTS,有的結(jié)構(gòu)變動(dòng)大的需要對(duì)應(yīng)字段關(guān)系,太麻煩;
所以我想到用數(shù)據(jù)庫結(jié)構(gòu)同步工具來進(jìn)行,記得以前就用過這個(gè)功能,我們可以在網(wǎng)上輕松找到oracle數(shù)據(jù)庫客戶端操作工具PLSQL Developer,這個(gè)工具除了對(duì)數(shù)據(jù)庫進(jìn)行日常的維護(hù)之外,還提供很多使用的功能,同步兩個(gè)數(shù)據(jù)庫的結(jié)構(gòu),就是其中一個(gè),操作步驟如下:
1、打開PLSQL Developer進(jìn)入新創(chuàng)建的數(shù)據(jù)庫;
打開菜單如下圖:
點(diǎn)擊菜單--工具--比較用戶對(duì)象,進(jìn)入如下圖:
會(huì)列出所以的表,你可選擇單獨(dú)的表或者多個(gè)表同時(shí)操作,然后點(diǎn)擊目標(biāo)回話,會(huì)彈出要同步的數(shù)據(jù)庫連接對(duì)象窗口,輸入用戶名和密碼等等,確定后點(diǎn)擊右下角的比較按鈕,這樣會(huì)出現(xiàn)如下的比較窗口:
這時(shí),會(huì)把不同之處用腳本列出來,只要點(diǎn)擊右邊的綠色對(duì)號(hào),同步即可;
這樣,結(jié)構(gòu)一下就都改好了,很方便。
一. 前言
這個(gè)問題是上一篇文章《Oracle跨數(shù)據(jù)庫實(shí)現(xiàn)定時(shí)同步指定表中的數(shù)據(jù)》中所提問題的進(jìn)一步延伸。考慮到對(duì)數(shù)據(jù)的實(shí)時(shí)性要求比較高,設(shè)置成定時(shí)同步,有點(diǎn)不妥,需要改善升級(jí)更改為實(shí)時(shí)同步。
下面介紹到的方式,嚴(yán)格意義上說,并沒有實(shí)現(xiàn)實(shí)時(shí)同步。是通過Oracle數(shù)據(jù)庫創(chuàng)建同義詞+DBlink的方式,來建立遠(yuǎn)程映射。在查看數(shù)據(jù)時(shí),直接去遠(yuǎn)程查詢?cè)磶熘械谋怼?/p>
而我一直關(guān)注的是如何進(jìn)行同步數(shù)據(jù),卻沒有考慮到可以建立映射。另外,還有一點(diǎn)就是需要交代,就是同步到目標(biāo)數(shù)據(jù)庫中的表,不進(jìn)行增刪改操作,只進(jìn)行查詢的操作,這也是可以使用同義詞方式解決問題的關(guān)鍵。
這種解決思路的出現(xiàn),多虧了在CSDN問答時(shí),熱心網(wǎng)友的回答,下面就是問題詳情描述。
二. 問題描述
有兩個(gè)Oracle數(shù)據(jù)庫,分別布置在不同的服務(wù)器上,系統(tǒng)均為windows2003;
這里暫且說成是一個(gè)主數(shù)據(jù)庫和從數(shù)據(jù)庫:
(1) 主數(shù)據(jù)庫:oracle_A;
(2) 從數(shù)據(jù)庫:oracle_B;
在oracle_A中有一個(gè)表table_A與oracle_B中的表table_B結(jié)構(gòu)相同;
我是處在oracle_B,oracle_A數(shù)據(jù)庫分配給我有一個(gè)訪問oracle_A表table_A的用戶,該用戶只擁有查詢的權(quán)限;
另外,需要說明的一點(diǎn),就是在oracle_B處,只需對(duì)table_B表進(jìn)行查詢的操作,不進(jìn)行其他增刪改的操作。
場(chǎng)景介紹完了,我的問題的是,如何在oracle_A中表table_A發(fā)生變化時(shí),實(shí)時(shí)更新同步到oracle_B的table_B中?
我原來的處理方式:
通過建立遠(yuǎn)程連接DBLink+JOB定時(shí)任務(wù)+存儲(chǔ)過程的方式,實(shí)現(xiàn)了定時(shí)同步更新,但不能做到實(shí)時(shí)同步。
三. 采用同義詞+DB_Link的方式結(jié)果步驟
之所以能夠選擇采用同義詞的方式,處理這個(gè)問題。主要還是源于在問題描述中提到一個(gè)點(diǎn),那就是我們只需要對(duì)同步后的表進(jìn)行查詢操作。這點(diǎn)是使用同義詞方式的重要要素。
下面詳細(xì)模擬一下整個(gè)實(shí)驗(yàn)測(cè)試的過程:
(1)首先在Oracle_A端創(chuàng)建一個(gè)對(duì)table_A只有查詢功能的用戶
1 創(chuàng)建用戶
sqlplus /nolog
conn /as sysdba;
create user username identified by password;
2 查看所有的用戶列表
用戶創(chuàng)建完成后,查看用戶是否創(chuàng)建成功
select * from all_users;
3授予權(quán)限
為了能夠保證能夠登陸,必須賦予如下權(quán)限
--授予username用戶創(chuàng)建session的權(quán)限,即登陸權(quán)限
grant create session to username;
--授予username用戶使用表空間的權(quán)限
grant unlimited tablespace to username;
--oracle對(duì)權(quán)限管理比較嚴(yán)謹(jǐn),普通用戶之間也是默認(rèn)不能互相訪問的,需要互相授權(quán).
--如果scott用戶要授權(quán)給username用戶查看自己的test表的權(quán)限;
sqlplus scott/tiget@localhost:1521/orcl
--授予username用戶查看指定的權(quán)限
grant select on test to username;
--撤銷權(quán)限
基本語法同grant,關(guān)鍵字為revoke;
(2)驗(yàn)證用戶是否可以成功登錄,并進(jìn)行訪問授權(quán)的表
--使用sqlplus登錄,并進(jìn)行查詢
sqlplus username/password@localhost:1521/orcl;
select * from scott.test;
注意:查詢表時(shí),務(wù)必帶上用戶名,說明是哪個(gè)用戶下的表。
(3)創(chuàng)建遠(yuǎn)程連接DB_Link
1 創(chuàng)建遠(yuǎn)程連接 db_link
create public database link db32 connect to tianzhi_test identified by "tianzhi_test" using '192.168.56.6:1521/ORCL'
2 測(cè)試遠(yuǎn)程連接是否成功
select * from tianzhi_smart.zh_item_news@db32;
(4)在Oracle_B端創(chuàng)建同義詞
1 使用sqlplus登錄自己的用戶
sqlplus tianzhi_smart/tianzhi_smart@localhost:1521/orcl
2 創(chuàng)建同義詞
create or replace public synonym TEST1130 for scott.TEST@db32;
3 查詢測(cè)試
select * from TEST1130;
可以看到這與在Oracle_A源數(shù)據(jù)庫中查到的table_A表中的數(shù)據(jù)一樣.
注意事項(xiàng):
當(dāng)遠(yuǎn)程查詢的數(shù)據(jù)庫中包含BLOB字段時(shí),會(huì)報(bào)出如下錯(cuò)誤.
ORA-22992: 無法使用從遠(yuǎn)程表選擇的 LOB 定位器
當(dāng)出現(xiàn)這個(gè)錯(cuò)誤的時(shí)候,那是因?yàn)榭鐜爝B接查詢中的表中存在BLOB類型的字段,所以一定要注意,所有表中存在blob類型字段,
不能用 select * from 連接的表
不能將blob類型的字段出現(xiàn)在腳本中。
如果這些blob類型的字段一定要導(dǎo)過來,可以先建立臨時(shí)表再插入本地表,方法如下.在pl/sql中執(zhí)行
第一步 建臨時(shí)表
create global temporary table foo ( X BLOB )
on commit delete rows;
第二步 插入本地表
insert into foo select blobcolumn from remoteTable@dl_remote ;
本文標(biāo)題:oracle的同步怎么做,oracle數(shù)據(jù)庫同步解決方案
網(wǎng)址分享:http://vcdvsql.cn/article28/hsdcjp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、網(wǎng)站排名、響應(yīng)式網(wǎng)站、網(wǎng)站內(nèi)鏈、網(wǎng)站收錄、域名注冊(cè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)