oracle跨库查询的方法

作者:mdxy-dxy 时间:2023-07-18 03:15:35 

在Oracle本地数据库端执行赋权dbuser帐号

SQL> grant create database link to dbuser;

1.配置本地数据库服务器的tnsnames.ora文件



$vi $ORACLE_HOME/network/admin/tnsnames.ora

添加如下行,其中DBLINK为连接名(可自定义),HOST和PORT为数据库侦听的IP及端口,SERVICE_NAME为数据库的SID,


MEDIADBLINK =
(DESCRIPTION =
 (ADDRESS_LIST =
  (ADDRESS = (PROTOCOL = TCP)(HOST = 10.0.0.1)(PORT = 1521))
 )
 (CONNECT_DATA =
  (SERVICE_NAME = db)
 )
)

2.登录到本地数据库,创建database link

执行如下查询语句,其中MEDIADB为database link名(可自定义),MEDIADBLINK为先前在tnsnames.ora中定义的连接名,
dbuser为用户名,password为密码


-- Create database link
create database link MEDIADB
connect to dbuser identified by password
using 'MEDIADBLINK';

注意:这里不会验证用户名密码的正确性

3.使用链接的数据库

3.1 查询、删除和插入数据和操作本地的数据库是一样的,只不过表名需要写成“表名@database link名”,如


select * from table_name@MEDIADB ;

3.2 也可以为这个表创建一个同义词


create synonym aaa for table_name@MEDIADB ;

如下语句的效果和3.1中的一样


select * from aaa;

删除同义词的语句为


drop synonym aaa;

 以下是其他网友的补充:

 在Oracle本地数据库端执行赋权dbuser帐号

SQL> grant create database link to dbuser;

配置本地数据库服务器的tnsnames.ora文件
$ vi $ORACLE_HOME/network/admin/tnsnames.ora

增加需要远程连接服务器的连接配置,如:


ORCL_REMOTE =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = oradb )(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
)

登录到本地数据库,创建database link

执行如下查询语句,其中ORCL_LINK为database link名(可自定义),ORCL_REMOTE为先前在tnsnames.ora中定义的连接名,
dbuser为用户名,password为密码


create database link ORCL_LINK connect to dbuser identified by password using 'ORCL_REMOTE';

查询创建database link的2中方式:

1)、执行SQL语句。
select * from user_db_links; --用户 DB Link
select * from dba_db_links; --dba DB Link
select * from v$dblink; --当前DB Link

2)、在PL/SQL中,在左边浏览器中点击database links就可以看到数据库链路了。

使用链接的数据库

查询、删除和插入数据和操作本地的数据库是一样的,只不过表名需要写成“表名@database link名”,如


select * from table_name@ORCL_LINK

其它:

删除database link(本例中是ORCL_LINK)
SQL> Drop database link ORCL_LINK; 

标签:oracle,跨库查询
0
投稿

猜你喜欢

  • python3 requests 各种发送方式详解

    2021-04-06 09:03:22
  • Python中利用ItsDangerous快捷实现数据加密

    2022-06-09 23:24:41
  • MySQL8.0.23安装超详细教程

    2024-01-26 05:06:18
  • 详解python3中socket套接字的编码问题解决

    2023-09-11 20:28:48
  • 一文带你吃透什么是PHP中的序列化

    2023-06-12 19:44:20
  • Python 调用 ES、Solr、Phoenix的示例代码

    2023-10-03 04:52:57
  • 格式化数字ASP,PHP版

    2009-01-19 14:17:00
  • python中list.copy方法用法详解

    2023-09-16 11:48:30
  • Python爬虫爬取微博热搜保存为 Markdown 文件的源码

    2023-03-03 23:30:29
  • Python发送http请求解析返回json的实例

    2022-04-11 03:38:28
  • block 和 inline 的区别是?

    2009-12-08 13:00:00
  • 基于Python批量生成指定尺寸缩略图代码实例

    2021-12-15 14:58:48
  • laravel学习教程之存取器

    2023-06-07 20:01:12
  • Oracle常见错误代码的分析与解决

    2010-07-26 13:01:00
  • 禁止iframe脚本弹出的窗口覆盖了父窗口的方法

    2024-06-16 21:04:57
  • 远程连接阿里云SqlServer 2012 数据库服务器的图文教程

    2024-01-16 06:16:48
  • MySQL 查询缓存的实际应用代码示例

    2010-06-11 12:04:00
  • MySQL创建高性能索引的全步骤

    2024-01-26 16:56:58
  • sqlserver存储过程语法详解

    2024-01-21 04:43:53
  • Python可执行文件反编译教程(exe转py)

    2022-05-07 19:37:11
  • asp之家 网络编程 m.aspxhome.com