通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

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

环境描述:

集团数据库:Oracle 11g

部门数据库:Oracle 11g

使用的软件:PLSQL Developer 13

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

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

Database link:使用户可以通过一个数据库访问到另外一个远程数据库

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

Procedure:用来完成特定的数据操作(比如修改、插入、删除数据等,个人感觉类似于Java中Util类里的方法)

一 : 创建Database links

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

通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

2.打开后的界面

通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

①:连接的名称,可以自定义,建议命名规范为: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 右键选择新建

通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

2.打开界面如下

通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

第一行Name,输入要创建的Procedure的名称

第二行Parameters参数,视情况而定,无特殊要求的话可以直接删掉(光标定位到箭头所示位置,按)

最后点击确 定按钮

3.点击确定后的界面:

在begin 下编写需要执行的SQL 即可,添加,删除等对数据库进行更改的SQL语句记得要加commit

如图

4.编写完成后点击PLSQL 任务栏的执行按钮即可

通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

三 : 创建 DBMS_Job

1.在对象栏找到DBMS_Jobs 右键选择新建

通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

2.打开后界面如下

通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

① What 值:填写Procedure名称,多个以逗号(,)分割 最后分号(;)结尾

② 下一个日期:第一次执行从什么时间开始,立即开始为sysdate

③ 间隔: 每隔多长时间执行一次

每秒钟执行: sysdate+1/(246060)

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

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

3.配置完成后界面

通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

最后点击应用即可

四 : 演示

通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

Original: https://www.cnblogs.com/llysc/p/13217233.html
Author: Java挖坑工程师
Title: 通过PLSQL创建Database link,DBMS_Job,Procedure,实现Oracle跨库传输数据

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/569347/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • Docker系列-docker-compose安装

    1.简介 我们知道使用一个 Dockerfile 模板文件,可以让用户很方便的定义一个单独的应用容器。然而,在日常工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要…

    Java 2023年6月8日
    062
  • 不止面试02-JVM内存模型面试题详解

    第一部分:面试题 本篇文章我们将尝试回答以下问题: 描述一下jvm的内存结构 描述一下jvm的内存模型 谈一下你对常量池的理解 什么情况下会发生栈内存溢出?和内存溢出有什么不同? …

    Java 2023年6月15日
    090
  • SpringBoot中Tomcat和SpringMVC整合源码分析

    概述 ​ SpringBoot中集成官方的第三方组件是通过在POM文件中添加组件的starter的Maven依赖来完成的。添加相关的Maven依赖之后,会引入具体的jar包,在Sp…

    Java 2023年6月13日
    084
  • VS2017 打开WebService 提示已经在解决方案中打开了具有该名称的项目

    .net开发。用VS2017工具,打开VS2010创建的WebSevice工程时,提示工程不可用。 重新加载后提示:已经在解决方案中打开了具有该名称的项目。 该问题原因是因为启用了…

    Java 2023年6月8日
    064
  • 简易线程池的实现

    1 线程池 为了避免多线程操作过程种线程频繁申请和释放所带来的性能消耗,可以提前创建多个线程,当有任务到来时从线程池中选择一个线程执行,执行完后继续在线程池中待命。 核心是使用一个…

    Java 2023年5月30日
    0102
  • mysql慢查询日志总结

    查看慢查询是否开启: mysql>show variables like ‘%slow_query_log%’; Variable_name Valu…

    Java 2023年6月5日
    056
  • JPA作持久层操作

    JPA(Hibernate是jpa的实现) jpa是对实体类操作,从而通过封装好的接口直接设置数据库的表结构。虽然jpa可以直接通过编写java代码来操作数据库表结构,避免了sql…

    Java 2023年6月13日
    069
  • JeeSite Spring Cloud安装搭建

    引言 JeeSite Cloud 具备 JeeSite 4.x 的所有功能,是在 JeeSite 4.x 基础之上,完成的 Spring Cloud 分布式系统套件的整合。它利用 …

    Java 2023年6月5日
    081
  • Java 基础三、接口与内部类

    public interface Comparable<t> { int compareTo(T other); } public interface Comparab…

    Java 2023年6月16日
    066
  • [算法]“简简单单”的插入排序,你还没掌握吗?

    写在前边 大家好,我是melo,一名大二上软件工程在读生,经历了一年的摸滚,现在已经在工作室里边准备开发后台项目啦。不过这篇文章呢,还是想跟大家聊一聊数据结构与算法,学校也是大二上…

    Java 2023年6月5日
    075
  • day12

    package com.oop.demo03;public class Pet { String name; int age; public void shout(){ Syste…

    Java 2023年6月5日
    081
  • Java核心技术-内部类(上)

    Day7 内部类 定义在另一个类中的类 内部类🙆‍可以都对同一个包中的其他类隐藏 内部类可以访问定义这个内部类的作用域中的属性,包括私有属性 内部类总有一个隐式引用,指向创建它的外…

    Java 2023年6月5日
    064
  • 以Integer类型传参值不变来理解Java值传参

    最近在写代码的时候出了一个错误,由于对值引用理解的不深,将Integer传入方法中修改,以为传入后直接修改Integer中的值就不用写返回值接收了,虽然很快发现了问题,但还是来总结…

    Java 2023年5月29日
    071
  • JVM面试题(已归类)

    一年一度的面试高峰期又来了,技术学习群的很多朋友问我有没有关于JVM基础面试题,网上各种面试题没有分类很混乱,无法系统性参考学习。 于是,我就把之前整理的以及我面试过的真题和答案都…

    Java 2023年6月6日
    089
  • Docker 学习笔记一

    Docker 学习笔记一 1.Docker是什么? Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。让开发者打包他们的应用以及依赖包…

    Java 2023年6月16日
    0108
  • webpack快速入门(二):使用入门

    继续之前请确认你已经安装了nodejs 安装、初始化: 然后找个目录新建名为webpack-demo的文件夹,然后在命令行下进入该目录,执行以下命令: 一个初始化命令,会在当前目录…

    Java 2023年6月16日
    060
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球