经过PLSQL Developer建立Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

前一阵领导安排了一个任务:定时将集团数据库某表的数据同步至咱们公司服务器的数据库,感受比写增删改查SQL有趣,特地记录下来,但愿能帮到有相似需求的小伙伴,若有错误也但愿各位不吝指教

环境描述:数据库

  集团数据库:Oracle 11g服务器

  部门数据库:Oracle 11g网络

  使用的软件:PLSQL Developer 13测试

  网络环境:两个数据库处于同一局域网spa

先讲一下完成此任务须要用到哪些技术:

 

  Database link:使用户能够经过一个数据库访问到另一个远程数据库对象

  DBMS_Job:使ORACLE数据库按期执行特定的任务blog

  Procedure:用来完成特定的数据操做(好比修改、插入、删除数据等,我的感受相似于Java中Util类里的方法)同步

:建立Database links

  1.在PLSQL Developer对象栏找到Database links右键选择新建it

   

 

 

 

  2.打开后的界面
class

  

 

 

 

  ①:链接的名称,能够自定义,建议命名规范为: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/(24*60*60)

        每分钟执行:    sysdate+1/(24*60)

   也能够设置天天,每周,每个月等等,具体SQL能够百度,此处不作赘述

 

  3.配置完成后界面

  

 

   最后点击应用便可

 

 :演示

 

 

 

相关文章
相关标签/搜索