Dblink Creation
Dblink Creation
Dblink Creation
6] Modified 08-OCT-2010 Type BULLETIN Status ARCHIVED Applies to: Oracle Server - Enterprise Edition - Version: 7.0.16.0 to 10.2.0.1 - Release: 7. 0 to 10.2 Information in this document applies to any platform. Checked for relevance on 6-April-2009 Purpose Describes how to create a public or private database link. Scope and Application Support engineers or database administrators. How To Create Private or Public Database Link
What is the correct syntax for creating a private or public database link? A database link is a schema object that causes ORACLE to connect to a remote database to an object there. In other words, database links are used to define paths to related remote databases. Syntax: CREATE {PUBLIC} DATABASE LINK {CONNECT TO IDENTIFIED BY } USING ''; Notes: - the default is for the Database Link to be created as a Private - use the CONNECT TO option if you want to access the remote database with a different Oracle USERID (i.e. not the one currently logged in). - must correspond to the name of the database to which the database link refers if parameter GLOBAL_NAMES=TRUE - is a valid SQL*Net connect string found in tnsnames.ora EXAMPLE: You would like to be able to connect from database "mps07db1" to database "mps07db3". This is based on the service name (alias) of "db3" and "db_name" of "mps07db3": TNSNAMES.ORA ============ db3= (DESCRIPTION= (ADDRESS_LIST= (ADDRESS= (PROTOCOL=TCP) (HOST=mps07) (PORT=1543) ) ) (CONNECT_DATA= (SID=mps07db3) ) )
Note: omitting the KEYWORD PUBLIC will automatically create PRIVATE database links. CREATE [PUBLIC] DATABASE LINK mps07db3 CONNECT TO TC IDENTIFIED BY TIMEPRD USING 'db3'; or CREATE [PUBLIC] DATABASE LINK mps07db3 CONNECT TO TC IDENTIFIED BY TIMEPRD USING 'db3.world'; TEST EXAMPLE OF CREATING A DATABASE LINK: ========================================= Database Global Name: V734 tnsnames.ora alias: wally_V734.world DBLINK TEST: Using V804 database as local database and V734 database as remote database. First you need to create user sadavid and grant privileges to sadavid. create user sadavid identified by sadavid; Grant dba to sadavid; grant unlimited tablespace to sadavid; alter user sadavid identified by sadavid default tablespace userdata; alter user sadavid quota unlimited on USERDATA; connect sadavid/sadavid ******************************************************************** 1) Connected to V734 database and do select from "global_name" to find out "global_name". Do show parameter global to find out if "global_names" is set to TRUE. select * from global_name; GLOBAL_NAME -----------------------------------------------------------------------V734.WORLD 1 row selected. Show parameter global NAME TYPE VALUE ----------------------------------- ------- ---------------------------global_names boolean TRUE
************************************************************************ 2) Find "TNSNAMES.ORA" file which will show service name (alias) for databases. For V734 you can see that the alias is "wally_V734.world". "TNSNANES.ORA" for tiger 5 is located in the following directory: /u01/app/oracle/propduct/8.0.4/network/admin
Look at "tnsnames.ora" file: wally_V734.world = (DESCRIPTION = (ADDRESS = (PROTOCOL= TCP)(Host= 138.1.102.165)(Port= 1521)) (CONNECT_DATA = (SID = V734)) *********************************************************************** 3) If you create a database link named SHIRLEY and using alias from "TNSNAMES.ORA". You will get ORA-2085 error. Oracle Server Manager Release 3.0.4.0.0 - Production (c) Copyright 1997, Oracle Corporation. All Rights Reserved. Oracle8 Enterprise Edition Release 8.0.4.3.0 - Production With the Partitioning and Objects options PL/SQL Release 8.0.4.3.0 - Production SVRMGR> connect sadavid/sadavid Connected. SVRMGR> CREATE [PUBLIC] DATABASE LINK SHIRLEY 2> CONNECT TO sadavid identified by sadavid 3> USING 'wally_V734.world'; Statement processed. SVRMGR> SELECT * FROM GLOBAL_NAMES@SHIRLEY; SELECT * FROM GLOBAL_NAME@SHIRLEY * ORA-02085: database link SHIRLEY.WORLD connects to V734.WORLD Cause: The database link attempted to connect to a database with a different name. The name of the database link must be the same as the name of the database. Action: Create a database link with the same name as the database to which it connects. See <19367.1> OERR: ORA 2085 "database link %s connects to %s" for further explanation of the error and workaround involving init.ora parameter GLOBAL_NAMES. *********************************************************************** 4) Create another dblink naming the link the same as database name(V734) and make sure that you are using correct alias per "tnsnames.ora" ('wally_V734.world'). CREATE [PUBLIC] DATABASE LINK V734 CONNECT TO sadavid identified by sadavid USING 'wally_V734.world'; Statement processed. *********************************************************************** 5) Select across DBLINK to V734 database is successful.
select * from global_name@V734; GLOBAL_NAME -----------------------------------------------------------------------V734.WORLD 1 row selected. Solution Explanation: ===================== Once you have service name (alias) and "db_name" from "tnsnames.ora", you will be able to successfully create your database link and do a select across the database link. Oracle 8 : ========== Note that Net8 also allows you to create a working database link when is not an alias defined in the tnsnames.ora file but a fully qualified connect string as in the following example: create database link V805.NL.ORACLE.COM connect to repadmin identified by repadmin using '(description=(address=(protocol=tcp)(host=nldock0592.nl.oracle.com) (Port = 1521) ) (connect_data= (sid=v805)))'; This can be very useful when the server side tnsnames.ora file does not have the same connect strings for database services as your local tnsnames.ora, for example if you connect scott/tiger@alias but a database link using 'alias' does not work, you can use the complete string as in the example.