在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
Oracle创建、删除DATABASE LINK create database link [name] connect to [username] IDENTIFIED BY [password] using '(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = [ip])(PORT = [port])) ) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = xxx) ) )'; 例如: create public database link dblink_name connect to SYSTEM using '192.168.1.73:1521/oracle'; 删除dblink: DROP DATABASE LINK [name]; --或 DROP PUBLIC DATABASE LINK [name]; 今天在试着删除的时候报错: ALTER SESSION CLOSE DATABASE LINK [name]; 但是报错: SELECT * FROM v$dblink; 下面是其它网友的补充大家可以参考下: 数据库全局名称可以用以下命令查出: 复制代码 代码如下: SELECT * FROM GLOBAL_NAME; 修改可以用以下语句来修改参数值: ALTER SYSTEM SET GLOBAL_NAME=TRUE/FALSE; <1>、当数据库参数global_name=false时,就不要求数据库链接名称跟远端数据库名称一样。 Oracle数据库之间进行连接通讯。 CREATE [PUBLIC] DATABASE LINK link CONNECT TO username IDENTIFIED BY password USING ‘connectstring' 注意:创建数据库链接的帐号必须有CREATE DATABASE LINK或CREATE PUBLIC DATABASE LINK的系统权限,用来登录到远程数据库的帐号必须有CREATE SESSION权限。这两种权限都包含在CONNECT角色中(CREATE PUBLIC DATABASE LINK权限在DBA中)。 一个公用数据库链接对于数据库中的所有用户都是可用的,而一个私有链接仅对创建它的用户可用。由一个用户给另外一个用户授权私有数据库链接是不可能的,一个数据库链接要么是公用的,要么是私有的。 创建数据库链接时,还可以使用缺省登录方式,即不指定远程数据库的用户名和密码: 复制代码 代码如下: create public database link zrhs_link using ‘zrhs'; 在不指定用户名和口令的情况下,ORACLE使用当前的用户名和口令登录到远程数据库。 USING后面指定的是链接字符串,也就是远程数据库的网络服务名,这个服务名保存在本地TNSNAMES.ORA文件中,在该文件中定义了协议、主机名、端口和数据库名。 删除数据库链接的语句是: 复制代码 代码如下: DROP [PUBLIC] DATABASE LINK zrhs_link 数据库链接的引用 一般情况下引用数据库链接,可以直接将其放到调用的表名或视图名称后面,中间使用一个 @ 作为分割符: SELECT * FROM worker@zrhs_link; 对于经常使用的数据库链接,可以建立一个本地的同义词,方便使用: CREATE SYNONYM worker_syn FOR worker@zrhs_link; 还可以建立一个本地的远程视图,方便使用: CREATE VIEW worker AS SELECT * FROM worker@zrhs_link where… ; 现在本视图可与本地数据库中的任何其它视图一样对待,也可以授权给其它用户,访问此视图,但该用户必须有访问数据库链接的权限。 对于另外一种情况,所要访问的表不在数据库链接中指定的远程帐户下,但该帐户有访问该表的权限,那么我们在表名前要加上该表的用户名: SELECT * FROM camel.worker@zrhs_link ; <2>、当数据库参数global_name=true时,那就要求数据库链接名称跟远端数据库全局名称一样 数据库全局名称可以用以下命令查出 SELECT * FROM GLOBAL_NAME; 创建dblink的语法: sql>create database link 数据库链路名 如: sql>create database link ora9i.us.oracle.com ### 这里的us.oracle.com为oracle默认域名 ### connect to scott identified by tiger using 'sun'; 1)dblink名必须与远程数据库的全局数据库名(global_name)相同; 如: sql>select * from 表名@ora9i.us.oracle.com; SQL>select owner,object_name from dba_objects where object_type='DATABASE LINK'; 下面对第二种情况进行举例说明: 北京的总部有一个集中的数据库,其SID是SIDBJ,用户名:userbj,密码:bj123,北京的IP地址是:192.168.1.101。 也可以通过查看v$option视图,如果其中Advanced replication为TRUE,则支持高级复制功能;否则不支持。 1、在本地建立一个Oracle的客户端连接tns_xj_to_bj,用于连接北京的数据库。 |
请发表评论