Oracle global database name與db link的糾纏關係

来源:http://www.cnblogs.com/kerrycode/archive/2016/06/08/5569473.html
-Advertisement-
Play Games

ORACLE資料庫中Global Database Name與DB LINKS的關係還真是有點糾纏不清,在說清楚這個關係前,我們先來瞭解一下Global Database Name的概念 Global DataBase Name 概念 1. What is a global database nam... ...


  ORACLE資料庫中Global Database Name與DB LINKS的關係還真是有點糾纏不清,在說清楚這個關係前,我們先來瞭解一下Global Database Name的概念

 

Global DataBase Name 概念

1. What is a global database name?

-------------------------------------------------------------------------------

The global database name is the unique name of the database. In a distributed

database system (a set of databases stored on multiple computers that typically

appears to applications as a single database) the global database name ensures

that each database is distinct from all other databases in the system. Oracle

forms a database's global database name by prefixing the database's network

domain with the individual database's name. For example: sales.us.oracle.com

and sales.uk.oracle.com.

The global database name defaults to DB_NAME.DB_DOMAIN and this value is marked

at database creation time. If you change the DB_NAME or DB_DOMAIN after the

database has been created, the value for the global database name (GLOBAL_NAME)

will not change.

說簡單一點,global database name就是用來唯一標識資料庫的東東。global database name由兩部分組成,DB_NAME和DB_DOMAIN。在創建db link的時候,Oracle會自動將db_domain作為尾碼添加上去。而且一旦加入就很難變更。所以在進行高級複製、Streams複製等配置時,最好首先將多個節點的global_name規劃好。

 

如何查看Global Database Name

 

SQL> select * from global_name;
 
GLOBAL_NAME
--------------------------------------------------------------------------------
TEST.REGRESS.RDBMS.DEV.US.ORACLE.COM
 
SQL> 

如下所示,可以知道global_name為一個視圖。

 

SQL> select object_name,object_type from dba_objects where object_name=upper('global_name');
 
OBJECT_NAME                              OBJECT_TYPE
---------------------------------------- -------------------------------
GLOBAL_NAME                              VIEW
GLOBAL_NAME                              SYNONYM

視圖global_name的定義可以從DBA_VIEWS裡面查看,如下所示,它來源於sys.props$內部表

select value$ from sys.props$ where name = 'GLOBAL_DB_NAME'

那麼參數global_name與Global Database Name又沒有區別呢? 其實參數global_name僅僅表示指定資料庫的鏈接是否需要和它所連接的資料庫相同的名稱。

GLOBAL_NAMES specifies whether a database link is required to have the same name as the database to which it connects.

SQL> show parameter global_name
 
NAME                                 TYPE        VALUE
---------------------------------- ----------- -----------------
global_names                         boolean     FALSE
SQL> 

所以兩者完全是兩個不同的概念,但是global_name也很重要,因為它的值會影響DB LINK.接下來,我們來創建一個DB Link,如下所示

SQL> select * from global_name;
 
GLOBAL_NAME
-------------------------------------
KKK.REGRESS.RDBMS.DEV.US.ORACLE.COM
 
SQL> CREATE PUBLIC DATABASE LINK "TEST"
     CONNECT TO "test" IDENTIFIED BY test1111
     USING '(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = 
     (PROTOCOL = TCP)(HOST = 192.168.27.109)(PORT = 1521)))
              (CONNECT_DATA = (SERVICE_NAME = QWR)))';
 
Database link created.
 
SQL> 

clip_image001

如上所示,我創建的DB Link名字為TEST,但是你查詢DBA_DB_LINKS時,你會發現鏈接伺服器自動加上了功能變數名稱,變成了TEST.REGRESS.RDBMS.DEV.US.ORACLE.COM, 當你查詢時,使用TEST或TEST.REGRESS.RDBMS.DEV.US.ORACLE.COM都OK。

SQL> SELECT * FROM DUAL@TEST;
 
D
-
X
 
SQL> SELECT * FROM [email protected];
 
D
-
X
 
SQL> 

clip_image002

 

當Global Database Name只有DB_NAME,但是沒有DB_DOMAIN時,此時,如果創建的DB Link是沒有db_domain作為尾碼添加上去的,你查詢時,就必須使用全名TEST.REGRESS.RDBMS.DEV.US.ORACLE.COM,不能像上面那樣使用TEST,否則會報ORA-02019: connection description for remote database not found 錯誤。

SQL> select * from global_name;
 
GLOBAL_NAME
--------------------------------------------------------------------------------
EPPS
 
SQLCREATE PUBLIC DATABASE LINK "TEST.REGRESS.RDBMS.DEV.US.ORACLE.COM"
  2     CONNECT TO "test" IDENTIFIED BY test1111
  3     USING '(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = 
         (PROTOCOL = TCP)(HOST = 192.168.27.109)(PORT = 1521)))(CONNECT_DATA = (SERVICE_NAME = QWR)))';  
 
Database link created.
SQL> SELECT * FROM DUAL@TEST;
SELECT * FROM DUAL@TEST
                   *
ERROR at line 1:
ORA-02019: connection description for remote database not found
 
 
SQL> SELECT * FROM [email protected];
 
D
-
X
 
SQL> 

clip_image003

 

DB_LINK與GLOBAL_NAMES參數的關係

   當GLOBAL_NAMES為TURE時,影響的是創建資料庫鏈接的那個庫對資料庫鏈接的使用。而不是鏈接到該資料庫的鏈接伺服器的使用。也就是說,如果一個庫(實例)的global_names參數設值為TRUE,則該庫連接其他庫的資料庫鏈接,其名稱必須要與被連接的庫的global_name相同,是否有點繞口,那麼從下麵實驗看看。

 

伺服器B

SQL> show parameter global_names;
 
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
global_names                         boolean     FALSE
SQL> select * from global_name;
 
GLOBAL_NAME
--------------------------------------------------------------------------------
KKK.REGRESS.RDBMS.DEV.US.ORACLE.COM

伺服器A

SQL> show parameter global_name;
 
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
global_names                         boolean     FALSE
SQL> select * from global_name;
 
GLOBAL_NAME
--------------------------------------------------------------------------------
SCM2.REGRESS.RDBMS.DEV.US.ORACLE.COM

在伺服器B上創建鏈接伺服器,鏈接到伺服器A

SQLCREATE PUBLIC DATABASE LINK "LINK1"
  2     CONNECT TO "test" IDENTIFIED BY test1111
  3     USING 'SERVER_A';
 
Database link created.
 
 
SQL> SELECT * FROM DUAL@LINK1;
 
	   

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、蘋果開發者賬號分類 按價格分類 免費 ① 個人申請賬號 僅可以用於真機調試 ② 院校賬號 僅可以用於真機調試 通過蘋果認證的高校可以使用 99$ ① 個人賬號 ② 企業(公司)賬號 申請所需的條件:需要法人信息、營業執照、鄧白氏編碼 使用:用於上傳APP到AppStore 299$ ① 企業賬號 ...
  • 一,效果圖。 二,代碼。 RootViewController.m - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. //電話號碼 UILabel *telLab ...
  • 冒泡排序 int temp ; int array[10] = {9,8,7,6,5,4,3,2}; for (int i = 0; i < 8; i ++) { for (int j = i+1; j < 8; j ++) { if (array[i] > array[j]) { temp = a ...
  • NSLog(@"%@",NSStringFromCGRect(switch.frame)); 或者 CFShow(NSStringFromCGRect(switch.frame)); 列印 CGSize : NSLog(@"%@",NSStringFromCGSize(someCG Size )); ...
  • 需要的軟體如沒有提供下載鏈接,文章中會註明! 首先下載 eclipse 安裝!(筆者提供的鏈接中沒有Eclipse下載!) 安裝完之後下載Jdk1.7安裝。 然後配置JDK跟ADT的環境變數。在此我提供會提供個一鍵配置的工具。請自行下載。大神當然請略過! 安卓工具下載:https://yunpan. ...
  • 一、極光推送工程端 1、下載SDK 極光推送是一個推送消息的第三方,SDK下載:https://www.jpush.cn/common/products 集成壓縮包內容:包名為JPush-iOS-SDK-{版本號} lib文件夾:包含頭文件 JPUSHService.h,靜態庫文件jpush-ios ...
  • 前幾篇文章已經從整體提供了診斷資料庫的各個方面問題的基本思路...也許對你很有用,也許你覺得離自己太遠。那麼今天我們從語句的一些優化寫法及一些簡單優化方法做一個介紹。這對於很多開發人員來說還是很有用的!為了方便閱讀給出前文鏈接: SQL SERVER全面優化 Expert for SQL Serve ...
  • 解決SQLSERVER2008 CPU使用率99%: 1、dbcc checkdb 重建索引 2、檢查有沒有死鎖 -- sp_lock SELECT request_session_id spid , OBJECT_NAME(resource_associated_entity_id) tableN ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...