在Oracle下如何創(chuàng)建database link全面總結(jié) |
發(fā)布時間: 2012/8/26 15:23:23 |
物理上存放于網(wǎng)絡(luò)的多個Oracle數(shù)據(jù)庫,邏輯上可以看成一個單一的大型數(shù)據(jù)庫,用戶可以通過網(wǎng)絡(luò)對異地數(shù)據(jù)庫中的數(shù)據(jù)進行存取,而服務(wù)器之間的協(xié)同處理對于工作站用戶及應(yīng)用程序而言是完全透明的,開發(fā)人員無需關(guān)心網(wǎng)絡(luò)的鏈接細節(jié)、數(shù)據(jù)在網(wǎng)絡(luò)節(jié)點中的具體分布情況和服務(wù)器間的協(xié)調(diào)工作過程。 數(shù)據(jù)庫之間的鏈接建立在DATABASE LINK上。要創(chuàng)建一個DATABASE LINK,必須首先在建立鏈接的數(shù)據(jù)庫上設(shè)置鏈接字符串,即配置一個遠程數(shù)據(jù)庫的本地網(wǎng)絡(luò)服務(wù)名。 鏈接字符串的配置參見《客戶端連接服務(wù)器》一節(jié)。
SELECT * FROM GLOBAL_NAME; 修改可以用以下語句來修改參數(shù)值: ALTER SYSTEM SET GLOBAL_NAME=TRUE/FALSE; <1>、當(dāng)數(shù)據(jù)庫參數(shù)global_name=false時,就不要求數(shù)據(jù)庫鏈接名稱跟遠端數(shù)據(jù)庫名稱一樣。 Oracle數(shù)據(jù)庫之間進行連接通訊。 CONNECT TO username IDENTIFIED BY password USING ‘connectstring’ 其中: 注意:創(chuàng)建數(shù)據(jù)庫鏈接的帳號必須有CREATE DATABASE LINK或CREATE PUBLIC DATABASE LINK的系統(tǒng)權(quán)限,用來登錄到遠程數(shù)據(jù)庫的帳號必須有CREATE SESSION權(quán)限。這兩種權(quán)限都包含在CONNECT角色中(CREATE PUBLIC DATABASE LINK權(quán)限在DBA中)。 一個公用數(shù)據(jù)庫鏈接對于數(shù)據(jù)庫中的所有用戶都是可用的,而一個私有鏈接僅對創(chuàng)建它的用戶可用。由一個用戶給另外一個用戶授權(quán)私有數(shù)據(jù)庫鏈接是不可能的,一個數(shù)據(jù)庫鏈接要么是公用的,要么是私有的。 創(chuàng)建數(shù)據(jù)庫鏈接時,還可以使用缺省登錄方式,即不指定遠程數(shù)據(jù)庫的用戶名和密碼: create public database link zrhs_link using ‘zrhs’; 在不指定用戶名和口令的情況下,Oracle使用當(dāng)前的用戶名和口令登錄到遠程數(shù)據(jù)庫。 USING后面指定的是鏈接字符串,也就是遠程數(shù)據(jù)庫的網(wǎng)絡(luò)服務(wù)名,這個服務(wù)名保存在TNSNAMES.ORA文件中,在該文件中定義了協(xié)議、主機名、端口和數(shù)據(jù)庫名。 (如果有兩臺數(shù)據(jù)庫服務(wù)器db_A和db_B,db_A下用戶user_a需要用database link訪問到db_B下user_b的數(shù)據(jù)時,有如下步驟:1、首先用戶user_b,這個用戶必須要有select 權(quán)限.2、在db_B上的tnsnames.ora中需要建立一個連接字符串tnsname_BtoA,可以從db_B連接到db_A。3、在db_A上的tnsnames.ora中需要建立一個連接字符串tnsname_AtoB,可以從db_A連接到db_B。4、然后在登陸到db_A上建立db link,格式如下: create database link link_AtoB_name connect to user_b identified by user_b的password using 'tnsname_AtoB'; link_AtoB_name必須是遠程數(shù)據(jù)庫的全局名(SID), tnsname_AtoB就是到遠程的連接字符串。5、測試是否能夠讀取數(shù)據(jù)。select * from dual@link_AtoB_name結(jié)果為: DUMMY X表示設(shè)置成功。) 刪除數(shù)據(jù)庫鏈接的語句是: DROP [PUBLIC] DATABASE LINK zrhs_link 數(shù)據(jù)庫鏈接的引用 一般情況下引用數(shù)據(jù)庫鏈接,可以直接將其放到調(diào)用的表名或視圖名稱后面,中間使用一個 @ 作為分割符: SELECT * FROM worker@zrhs_link; 對于經(jīng)常使用的數(shù)據(jù)庫鏈接,可以建立一個本地的同義詞,方便使用: CREATE SYNONYM worker_syn FOR worker@zrhs_link; 還可以建立一個本地的遠程視圖,方便使用: CREATE VIEW worker AS SELECT * FROM worker@zrhs_link where… ; 現(xiàn)在本視圖可與本地數(shù)據(jù)庫中的任何其它視圖一樣對待,也可以授權(quán)給其它用戶,訪問此視圖,但該用戶必須有訪問數(shù)據(jù)庫鏈接的權(quán)限。 對于另外一種情況,所要訪問的表不在數(shù)據(jù)庫鏈接中指定的遠程帳戶下,但該帳戶有訪問該表的權(quán)限,那么我們在表名前要加上該表的用戶名: SELECT * FROM camel.worker@zrhs_link ; <2>、當(dāng)數(shù)據(jù)庫參數(shù)global_name=true時,那就要求數(shù)據(jù)庫鏈接名稱跟遠端數(shù)據(jù)庫名稱一樣 SELECT * FROM GLOBAL_NAME; atabase link(dblink)--數(shù)據(jù)庫鏈路 1)dblink名必須與遠程數(shù)據(jù)庫的全局?jǐn)?shù)據(jù)庫名(global_name)相同; 查看所有的數(shù)據(jù)庫鏈接,進入系統(tǒng)管理員SQL>操作符下,運行命令: SQL>select owner,object_name from dba_objects where object_type='DATABASE LINK' 本文出自:億恩科技【www.allwellnessguide.com】 服務(wù)器租用/服務(wù)器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM] |