通过PLSQL Developer创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据的方法(推荐)

所属分类: 数据库 / oracle 阅读数: 1168
收藏 0 赞 0 分享

前一阵领导安排了一个任务:定时将集团数据库某表的数据同步至我们公司服务器的数据库,感觉比写增删改查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/(24*60*60)

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

   也可以设置每天,每周,每月等等,具体SQL可以百度,此处不做赘述

  3.配置完成后界面

  

  最后点击应用即可

四:演示

更多精彩内容其他人还在看

Oracle 子程序参数模式,IN,OUT,NOCOPY

Oracle 子程序参数模式主要有IN,OUT,NOCOPY,IN和OUT可以组合,OUT和NOCOPY也可以组合使用.
收藏 0 赞 0 分享

Oracle 存储过程加密方法

Oracle 存储过程加密方法,需要的朋友可以参考下。
收藏 0 赞 0 分享

oracle 多个字符替换实现

CSDN上的一个网友,需要一个sql语句的解决方案需求是这样的求写oracle多个字符替换(有测试数据)
收藏 0 赞 0 分享

Oracle 存储过程教程

一个简单的oracle分页存储过程的实现和调用。在看了众多的分页存储过程以后发现都是针对sqlserver的,而没有oracle的,因此想写一个关于oracle的存储过程,因为我用到的数据库是oracle。
收藏 0 赞 0 分享

oracle 更改数据库名的方法

这两天一朋友问如何更改数据库名,于是做个测试,简单记录下,以便说明问题。
收藏 0 赞 0 分享

Oracle 分析函数RANK(),ROW_NUMBER(),LAG()等的使用方法

Oracle分析函数RANK(),ROW_NUMBER(),LAG()等的使用方法,需要的朋友可以参考下。
收藏 0 赞 0 分享

Oracle字符集修改查看方法

Oracle字符集修改查看方法,需要的朋友可以参考下。
收藏 0 赞 0 分享

一些实用的sql语句

一些实用的sql,需要的朋友可以参考下。
收藏 0 赞 0 分享

Oracle中sys和system的区别小结

SYS用户具有DBA权限,并且拥有SYS模式,只能通过SYSDBA登陆数据库。是Oracle数据库中权限最高的帐号 SYSTEM具有DBA权限。但没有SYSDBA权限。平常一般用该帐号管理数据库就可以了。
收藏 0 赞 0 分享

oracle 存储过程和触发器复制数据

oracle 存储过程和触发器复制数据的代码,需要的朋友可以参考下。
收藏 0 赞 0 分享
查看更多