码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【笔记】Oracle不同数据库之间的表级别同步


    工具:Oracle官方工具sqldeveloper

    题目描述:

            这两天在搞两个数据库的数据推送同步,当时想到有两个解决方案,在最开始的mapper层再加个数据源,数据插入时两个数据库一起写入,但是被否了,只好用DBlink+定时任务job执行存储过程的方式。

    实操解决:

            1、任务

    首先我有两个数据库 clgl 和 jjh 如图,任务是将 jjh 的TEST01表同步推送到 clgl 的同名 TEST01 表中:

            2、 DBlink

    任务确定之后,我们开始着手准备两个数据库之间的跨库连接,这里我们使用DBlink的方式。

    因为是jjh到clgl,所以我们在clgl表里创建DBlink,连接名为:TESTLINK,代码如下:

    1. --创建一个公共的数据库连接
    2. create public database link TESTLINK --连接的名字
    3. connect to jjh --连接的数据库名 jjh
    4. identified by "123456" --连接的数据库密码 jjh的密码
    5. using '192.168.10.110:1521/orcl'; --连接的地址 悬停在jjh上即可显示

    执行成功:

    我们可以在左侧列表看到这个DBlink:

            3、 创建同步的存储过程  存储过程名为TestProc

    代码如下:

    1. select * from TEST01;
    2. --上边的查询不用复制
    3. --进行表级别的同步 创建存储过程
    4. create or replace procedure TestProc --存储过程名为TestProc
    5. as
    6. begin
    7. delete from TEST01; --先删除clgl中的TEST01表
    8. insert into TEST01(ID,--再insert jjh库中的TEST01表
    9. NAME,
    10. SAL) select ID,
    11. NAME,
    12. SAL from TEST01@TESTLINK; --@前边是clgl的TEST01表名 @后边是DBlink名 TESTLINK
    13. dbms_output.put_line('XYB_JZJXSQ_SYQK同步成功!'); --打印
    14. commit;
    15. end;

     选中存储过程部分开始执行得到:

             4、创建任务job

    1. --创建任务JOB testJob
    2. variable job01 number; --任务名为job01
    3. --两段分开执行
    4. begin
    5. dbms_job.submit(job => :job01, --任务名
    6. what => 'TestProc;', --执行的存储过程名
    7. next_date => to_date('3-11-2022 01:00:00', 'dd-mm-yyyy hh24:mi:ss'),--执行开始时间为11.3的凌晨1点
    8. interval => 'sysdate+12/24'); --执行间隔为12个小时 即下次执行时间为11.3的中午1点
    9. commit;
    10. end;

     执行:     

    这里时间搞错了,当时时间为10::39,而写的凌晨1点早就过了,所以会自动间隔12小时到3号晚上的22:39才会执行。

            5、删除和修改

    目前笔者都是直接通过SQLdeveloper工具进行直接点点点操作的,方便又好使。

    笔记总结:

    遇到这种纯经验性的需求一定要多做笔记。

    参考链接:

    https://blog.csdn.net/UniRong/article/details/78671917

    http://ttps://segmentfault.com/a/1190000023044236

    http:// http://t.csdn.cn/n4lFs

    http://t.csdn.cn/78OMl

  • 相关阅读:
    【VM-Tools】Linux快速安装
    promise.race方式使用
    c++位域结构体 例如struct A{int a:2;};
    [Zer0pts2020]Can you guess it? basename特性 和preg_match 绕过
    人机交互中的既要、又要、还要
    Windows网络系统架构
    某Al行业四小龙之一:向空间要效率之前,向流程要效率
    【TES720D-KIT】基于复旦微FMQL20S400全国产化ARM开发套件(核心板+底板)
    Linux | 进程间通信 | 匿名管道 | 命名管道 | 模拟代码实现进程通信
    Linux 查看进程启动时间、运行时间
  • 原文地址:https://blog.csdn.net/qq_44739758/article/details/127663513
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号