oracle数据库中两张表分别在两个数据库中怎么能建关联?

oracle数据库中两张表分别在两个数据库中怎么能建关联?,第1张

create public batabase link a_to_b\x0d\x0aconnect to (被 *** 作表所在库的用户名) identified by (被 *** 作表所在库的密码)\x0d\x0ausing ‘(被 *** 作表所属实例名)’\x0d\x0a然后在 *** 作实例中进行测试:\x0d\x0aselect 1 from dual@a_to_b\x0d\x0a如果有正确结果 那么你就建立了一个dblink了。\x0d\x0a \x0d\x0a这个时候就可以 跨库查询了。

这个是可以的,不过要有权限,首先创建一个DBLINK,让数据库可以互相关联,假设要把A用户的a表数据复制给B用户b表就让B赋予连接A的权限,然后写SQL语句:INSERT INTO B.b (SELECT * FROM A.a) 这样就可以了。

背景:项目中遇到的问题,需要二区两台数据库之间同步一些表,以及导出sql文件同步至三区数据库。

新建SQL文件生成的目录D:mptmsudataDNLTBDIR。

二区数据库中执行下列语句:

1)新建二区数据库服务器到二区数据库服务器的数据库DATABASE LINK文件。

二区数据库中执行下列语句:

2)二区数据库服务器新建表DNL_TBJL。

二区数据库中执行下列语句:

在二区数据库服务器说新建相关表的触发器,触发器实现的功能是东区2区向西区直接通过DBLINK直接执行;东区2区向东区3区通过生成SQL文件到D:mptmsudataDNLTBDIR目录下;触发器的每次 *** 作都记录到表格DNL_TBJL(id, tables,czlx, SQL, TIME, BAK)内。

通过Windows系统自带的计划任务执行下面批处理实现数据入库

1)三区区数据库服务器新建表DNL_SQLJL。

三区数据库中执行下列语句:

2)三区区数据库服务器新建计划任务定期执行DQ3QRK-ZXWJ.bat批处理。

3)DQ3QRK-ZXWJ.bat批处理调用DQ3QRK-ZXSQL.bat来执行入库 *** 作。

DQ3QRK-ZXWJ.bat语句如下:

DQ3QRK-ZXSQL.bat语句如下:


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9613795.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存