在ORACLE里A庫(kù)里建立一個(gè)同義詞可把B庫(kù)的X 表映射到A庫(kù)。這樣A庫(kù)就當(dāng)本庫(kù)的表(虛擬式)使用。
成都創(chuàng)新互聯(lián)自2013年起,先為陸豐等服務(wù)建站,陸豐等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為陸豐企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。
Oracle的同義詞(synonyms)從字面上理解就是別名的意思,和試圖的功能類似,就是一種映射關(guān)系。本文介紹如何創(chuàng)建同義詞語(yǔ)句,刪除同義詞以及查看同義詞語(yǔ)句。
oracle的同義詞總結(jié):
從字面上理解就是別名的意思,和試圖的功能類似。就是一種映射關(guān)系。
1.創(chuàng)建同義詞語(yǔ)句:
create public synonym table_name for user.table_name;
其中第一個(gè)user_table和第二個(gè)user_table可以不一樣。
此外如果要?jiǎng)?chuàng)建一個(gè)遠(yuǎn)程的數(shù)據(jù)庫(kù)上的某張表的同義詞,需要先創(chuàng)建一個(gè)Database Link(數(shù)據(jù)庫(kù)連接)來(lái)擴(kuò)展訪問(wèn),然后在使用如下語(yǔ)句創(chuàng)建數(shù)據(jù)庫(kù)同義詞:create synonym table_name for table_name@DB_Link;
當(dāng)然,你可能需要在user用戶中給當(dāng)前用戶(user2)授權(quán): grant select/delete/update on user2
一. 前言
這個(gè)問(wèn)題是上一篇文章《Oracle跨數(shù)據(jù)庫(kù)實(shí)現(xiàn)定時(shí)同步指定表中的數(shù)據(jù)》中所提問(wèn)題的進(jìn)一步延伸??紤]到對(duì)數(shù)據(jù)的實(shí)時(shí)性要求比較高,設(shè)置成定時(shí)同步,有點(diǎn)不妥,需要改善升級(jí)更改為實(shí)時(shí)同步。
下面介紹到的方式,嚴(yán)格意義上說(shuō),并沒(méi)有實(shí)現(xiàn)實(shí)時(shí)同步。是通過(guò)Oracle數(shù)據(jù)庫(kù)創(chuàng)建同義詞+DBlink的方式,來(lái)建立遠(yuǎn)程映射。在查看數(shù)據(jù)時(shí),直接去遠(yuǎn)程查詢?cè)磶?kù)中的表。
而我一直關(guān)注的是如何進(jìn)行同步數(shù)據(jù),卻沒(méi)有考慮到可以建立映射。另外,還有一點(diǎn)就是需要交代,就是同步到目標(biāo)數(shù)據(jù)庫(kù)中的表,不進(jìn)行增刪改操作,只進(jìn)行查詢的操作,這也是可以使用同義詞方式解決問(wèn)題的關(guān)鍵。
這種解決思路的出現(xiàn),多虧了在CSDN問(wèn)答時(shí),熱心網(wǎng)友的回答,下面就是問(wèn)題詳情描述。
二. 問(wèn)題描述
有兩個(gè)Oracle數(shù)據(jù)庫(kù),分別布置在不同的服務(wù)器上,系統(tǒng)均為windows2003;
這里暫且說(shuō)成是一個(gè)主數(shù)據(jù)庫(kù)和從數(shù)據(jù)庫(kù):
(1) 主數(shù)據(jù)庫(kù):oracle_A;
(2) 從數(shù)據(jù)庫(kù):oracle_B;
在oracle_A中有一個(gè)表table_A與oracle_B中的表table_B結(jié)構(gòu)相同;
我是處在oracle_B,oracle_A數(shù)據(jù)庫(kù)分配給我有一個(gè)訪問(wèn)oracle_A表table_A的用戶,該用戶只擁有查詢的權(quán)限;
另外,需要說(shuō)明的一點(diǎn),就是在oracle_B處,只需對(duì)table_B表進(jìn)行查詢的操作,不進(jìn)行其他增刪改的操作。
場(chǎng)景介紹完了,我的問(wèn)題的是,如何在oracle_A中表table_A發(fā)生變化時(shí),實(shí)時(shí)更新同步到oracle_B的table_B中?
我原來(lái)的處理方式:
通過(guò)建立遠(yuǎn)程連接DBLink+JOB定時(shí)任務(wù)+存儲(chǔ)過(guò)程的方式,實(shí)現(xiàn)了定時(shí)同步更新,但不能做到實(shí)時(shí)同步。
三. 采用同義詞+DB_Link的方式結(jié)果步驟
之所以能夠選擇采用同義詞的方式,處理這個(gè)問(wèn)題。主要還是源于在問(wèn)題描述中提到一個(gè)點(diǎn),那就是我們只需要對(duì)同步后的表進(jìn)行查詢操作。這點(diǎn)是使用同義詞方式的重要要素。
下面詳細(xì)模擬一下整個(gè)實(shí)驗(yàn)測(cè)試的過(guò)程:
(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)不能互相訪問(wè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)限
基本語(yǔ)法同grant,關(guān)鍵字為revoke;
(2)驗(yàn)證用戶是否可以成功登錄,并進(jìn)行訪問(wèn)授權(quán)的表
--使用sqlplus登錄,并進(jìn)行查詢
sqlplus username/password@localhost:1521/orcl;
select * from scott.test;
注意:查詢表時(shí),務(wù)必帶上用戶名,說(shuō)明是哪個(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ù)庫(kù)中查到的table_A表中的數(shù)據(jù)一樣.
注意事項(xiàng):
當(dāng)遠(yuǎn)程查詢的數(shù)據(jù)庫(kù)中包含BLOB字段時(shí),會(huì)報(bào)出如下錯(cuò)誤.
ORA-22992: 無(wú)法使用從遠(yuǎn)程表選擇的 LOB 定位器
當(dāng)出現(xiàn)這個(gè)錯(cuò)誤的時(shí)候,那是因?yàn)榭鐜?kù)連接查詢中的表中存在BLOB類型的字段,所以一定要注意,所有表中存在blob類型字段,
不能用 select * from 連接的表
不能將blob類型的字段出現(xiàn)在腳本中。
如果這些blob類型的字段一定要導(dǎo)過(guò)來(lái),可以先建立臨時(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 ;
這個(gè)是可以的,不過(guò)要有權(quán)限,首先創(chuàng)建一個(gè)DBLINK,讓數(shù)據(jù)庫(kù)可以互相關(guān)聯(lián),假設(shè)要把A用戶的a表數(shù)據(jù)復(fù)制給B用戶b表就讓B賦予連接A的權(quán)限,然后寫(xiě)SQL語(yǔ)句:INSERT INTO B.b (SELECT * FROM A.a); ?這樣就可以了。