Oracle跨库访问DBLINK使用以及实际应用

 更新时间:2024年01月20日 14:49:45   作者:UntifA  
这篇文章主要给大家介绍了关于Oracle跨库访问DBLINK使用以及实际应用的相关资料,DBLink的作用是在局域网内,通过一台服务器上面的数据库访问另外一台服务器上面数据库的功能,需要的朋友可以参考下

1. DBLINK的介绍

Oracle在进行跨库访问时,可以创建DBLINK实现,比如要将UAT的表数据灌入开发环境,则可以使用UAT库为数据源,通过DBLINK实现将查出的数据灌入开发库。简而言之就是在当前数据库中访问另一个数据库中的表中的数据

2. DBLINK的使用简介

2.1 权限问题

要想创建DBLINK,首先要检查当前用户是否具备权限。

SELECT * FROM user_sys_privs WHERE PRIVILEGE LIKE UPPER('%DATABASE LINK%');

CREATE PUBLIC DATABASE LINK:表示所创建的dblink所有用户都可以使用
CREATE DATABASE LINK:表示所创建的dblink只能是创建者能使用,别的用户不可以使用
DROP PUBLIC DATABASE LINK : 表示所创建的dblink所用用户都可以删除

如果没有以上权限,但是有UNLIMITED TABLESPACE权限,也可以实现DBLINK的创建和删除(实测)。

SELECT * FROM user_sys_privs WHERE PRIVILEGE LIKE UPPER('%UNLIMITED TABLESPACE%');

如果指定用户没有上面的几个权限,需要通过sys用户(这个充当管理员角色,有很大权限)赋予权限,你需要登陆sys用户,并在sys用户下执行以下语句:

GRANT CREATE PUBLIC DATABASE LINK , DROP PUBLIC DATABASE LINK TO hxapp;

用来登录到远程数据库的帐号必须有CREATE SESSION权限

2.2 创建DBLINK

创建时加不加PUBLIC关键字,会影响DBLINK的使用范围,加上PUBLIC关键字则所有用户都可以使用,否则只有当前用户或者更高权限的用户可以使用。

  • 通过pl/sql developer图形化界面创建

    等价于
    CREATE DATABASE LINK DBLINK_TEST_TO230
      CONNECT TO hxapp IDENTIFIED BY hxapp
      USING '3.1.11.230/cbsznckdb';
    
  • 如果网络配置文件tnsnames.ora配置了连接信息,则可以使用如下语句实现:
    CREATE DATABASE LINK &dblink_name
    	CONNECT TO &db_name IDENTIFIED BY &db_passwd
    	USING '&db_sid';
    

  • 如果网络配置文件tnsnames.ora未配置连接信息,则可以使用如下语句实现:
CREATE DATABASE LINK &dblink_name
CONNECT TO &db_name IDENTIFIED BY &db_passwd
USING '(DESCRIPTION = 
         (ADDRESS_LIST =
           (ADDRESS =
             (PROTOCOL = TCP)
             (HOST = &ip)
             (PORT = 1521)
           )
         )
         (CONNECT_DATA = (SERVICE_NAME = &sid)
         )
       )';
--例:
CREATE DATABASE LINK &dblink_name
CONNECT TO &db_name IDENTIFIED BY &db_password
USING '(DESCRIPTION = 
         (ADDRESS_LIST =
           (ADDRESS =
             (PROTOCOL = TCP)
             (HOST = 3.1.11.230)
             (PORT = 1521)
           )
         )
         (CONNECT_DATA = (SERVICE_NAME = cbsznckdb)
         )
       )';
--简写
	CREATE DATABASE LINK DBLINK_TEST_01
	  CONNECT TO hxapp IDENTIFIED BY hxapp
	  USING '3.1.11.230/cbsznckdb';

创建以后查询结果:

2.3 查询DBLINK

  • 查询当前实例下所有的DBLINK
SELECT * FROM dba_db_links t;

  • 查询当前用户下所有的DBLINK
SELECT * FROM user_db_links t;

2.4 删除DBLINK

  • 如果创建的是一个public的DBLINK,删除时需要用
 DROP PUBLIC DATABASE LINK &dblink_name;
  • 如果创建的是一个private的DBLINK,删除时需要用
 DROP DATABASE LINK &dblink_name;

3. DBLINK实际应用语句举例

--插入语句
INSERT INTO test_01@DBLINK_TEST_01 t
  SELECT 'UntifA' FROM dual;
--查询语句
SELECT * FROM test_01@DBLINK_TEST_01 t WHERE t.name = 'UntifA';
--删除语句
DELETE FROM test_01@DBLINK_TEST_01 t WHERE t.name = 'UntifA';
--更新语句
UPDATE test_01@DBLINK_TEST_01 t
   SET t.name = 'mengkiD~lufy'
 WHERE t.name = 'UntifA';

总结 

到此这篇关于Oracle跨库访问DBLINK使用以及实际应用的文章就介绍到这了,更多相关Oracle跨库访问DBLINK内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • Oracle查询今天、昨天、本周、上周、本月、上月数据方式

    Oracle查询今天、昨天、本周、上周、本月、上月数据方式

    这篇文章主要介绍了Oracle查询今天、昨天、本周、上周、本月、上月数据方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • Oracle数据IMP和EXP命令用法详解

    Oracle数据IMP和EXP命令用法详解

    这篇文章主要给大家介绍了关于Oracle数据IMP和EXP命令用法详解的相关资料,我们可以使用Oracle自带的exp、imp命令来进行数据库备份,imp和exp称之为导入导出,这种方式也能快速的导入导出table或数据库,需要的朋友可以参考下
    2023-11-11
  • oracle数据库密码到期怎么解决

    oracle数据库密码到期怎么解决

    这篇文章主要介绍了oracle数据库密码到期的解决方法,非常不错,具有参考借鉴价值,需要的的朋友参考下
    2017-02-02
  • Oracle定义联合数组及使用技巧

    Oracle定义联合数组及使用技巧

    联合数组以前被称为PL/SQL表。在表中不能使用联合数组,只能将它们用作程序设计的结构体。只能在PL/SQL中访问联合数组
    2012-11-11
  • 深入浅析mybatis oracle BLOB类型字段保存与读取

    深入浅析mybatis oracle BLOB类型字段保存与读取

    本文给大家浅析mybatis oracle blob类型字段的保存与读取,blob字段是指二进制大对象,用来存储大量文本数据。感兴趣的朋友一起学习吧
    2015-10-10
  • Oracle 8i在P4上的安装

    Oracle 8i在P4上的安装

    Oracle 8i在P4上的安装...
    2007-03-03
  • ORACLE查看当前连接数的常见方法及解释

    ORACLE查看当前连接数的常见方法及解释

    做数据库开发的时候,有时候会遇到连接超出最大限制的问题,这时候,我们需要查看数据库的连接数,这篇文章主要介绍了ORACLE查看当前连接数的常见方法及解释,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-09-09
  • Oracle如何设置表空间数据文件大小

    Oracle如何设置表空间数据文件大小

    这篇文章主要介绍了Oracle如何设置表空间数据文件大小,文中讲解非常细致,帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • Oracle中查询结果合并的方法详解

    Oracle中查询结果合并的方法详解

    这篇文章主要给大家介绍了Oracle中查询结果合并的方法,利用union合并查询,利用intersect合并查询,利用“union all”合并查询,利用minus合并查询,需要的朋友可以参考下
    2023-08-08
  • Oracle Translate 统计字符出现的次数示例代码

    Oracle Translate 统计字符出现的次数示例代码

    这篇文章主要介绍了Oracle Translate 统计字符出现的次数示例代码,非常不错具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03

最新评论