前一阵领导安排了一个任务:定时将集团数据库某表的数据同步至我们公司服务器的数据库,感觉比写增删改查SQL有趣,特意记录下来,希望能帮到有类似需求的小伙伴,如有错误也希望各位不吝指教
环境描述:
集团数据库:Oracle 11g
部门数据库:Oracle 11g
使用的软件:PLSQL Developer 13
网络环境:两个数据库处于同一局域网
先讲一下完成此任务需要用到哪些技术:
Database link:使用户可以通过一个数据库访问到另外一个远程数据库
DBMS_Job:使ORACLE数据库定期执行特定的任务
Procedure:用来完成特定的数据操作(比如修改、插入、删除数据等,个人感觉类似于Java中Util类里的方法)
一 : 创建Database links
1.在PLSQL Developer对象栏找到Database links 右键选择新建
2.打开后的界面
①:连接的名称,可以自定义,建议命名规范为:connect_数据库名称
②:要连接的数据库的用户名,密码,以及地址,地址格式为IP:端口/数据库名称
③:保存
3.测试Database link是否创建成功
SQL 格式: Select * From 目标数据库的表名称@Database link 名称
假设对方有一张表为:AD_User,我们创建的Database link名称问connect_Server
则测试SQL如下: Select * From AD_User@connect_Server
二 : 创建 Procedure
1.在对象栏找到Procedures 右键选择新建
2.打开界面如下
第一行Name,输入要创建的Procedure的名称
第二行Parameters参数,视情况而定,无特殊要求的话可以直接删掉(光标定位到箭头所示位置,按)
最后点击确 定按钮
3.点击确定后的界面:
在begin 下编写需要执行的SQL 即可,添加,删除等对数据库进行更改的SQL语句记得要加commit
如图
4.编写完成后点击PLSQL 任务栏的执行按钮即可
三 : 创建 DBMS_Job
1.在对象栏找到DBMS_Jobs 右键选择新建
2.打开后界面如下
① What 值:填写Procedure名称,多个以逗号(,)分割 最后分号(;)结尾
② 下一个日期:第一次执行从什么时间开始,立即开始为sysdate
③ 间隔: 每隔多长时间执行一次
每秒钟执行: sysdate+1/(246060)
每分钟执行: sysdate+1/(24*60)
也可以设置每天,每周,每月等等,具体SQL可以百度,此处不做赘述
3.配置完成后界面
最后点击应用即可
四 : 演示
Original: https://www.cnblogs.com/llysc/p/13217233.html
Author: Java挖坑工程师
Title: 通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据
原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/569347/
转载文章受原作者版权保护。转载请注明原作者出处!