Navicat使用教程:使用Navicat Premium 12自动执行数据库复制(2)
wxin55 2024-10-27 15:54 13 浏览 0 评论
Navicat Premium是一个可连接多种数据库的管理工具,它可以让你以单一程序同时连接到MySQL、Oracle及PostgreSQL数据库,让管理不同类型的数据库更加的方便。
与同步不同,同步是一个一次性的过程,它使两个数据库的模式和数据同步,复制是一个连续(自动)在两个数据库之间复制数据的过程(尽管模式更新也是可能的)。复制可以异步进行,这样就不需要在两个数据库之间建立永久连接,或者在非高峰时间(例如,在深夜,数据库服务器上的通信量很少)进行复制。
复制的主要作用是创建所有用户数据库的合并存储库和/或在所有用户之间传播相同级别的信息。在这两种情况下,结果都是一个分布式数据库,在该数据库中,用户可以访问与其任务相关的数据,而不会干扰其他人的工作。为了消除用户之间的数据模糊性或不一致性而实现的数据库复制称为规范化。
这篇文章将介绍如何使用Navicat Premium的新自动化实用程序自动执行数据库复制。
快照复制
如上所述,快照复制通过将数据从一个数据库复制到同一个或不同服务器上的另一个数据库,使两个数据库保持同步。这是三种类型中最简单的一种。
创建数据同步作业
必须首先创建数据同步配置文件,以便将其作为复制过程自动化。在数据库同步策略白皮书中描述了在Navicat Premium 12中实现同质和异构同步的步骤。为了本教程的目的,我们将使用第一个示例来同步Sakila和Sakila2数据库。
提示:一旦创建了Sakila数据库,您可以通过右键单击导航窗格中的连接并选择新建数据库来创建Sakila2数据库。然后在弹出窗口中输入数据库名称(“sakila2”)。
要打开数据同步向导:
从菜单栏中选择Tools -> Data Synchronization。
"Data Synchronization Options”选项卡仅包含几个比较选项复选框。我们可以保持原样:
数据同步向导的下一步是映射表。可以通过下拉列表选择目标表。在这种情况下,我们不需要提供任何映射指令,因为两个数据库中的表是相同的:
比较数据后,窗口显示将在目标表中插入、更新或删除的记录数。如果不想包括具有相同数据的表或具有不同结构的表,也就是说,不更新的表,可以取消选中“Show identical table and others”选项。还有一些复选框可以取消选择表或不希望应用于目标的操作。
在列表中选择一个表将在底部窗格中显示源表和目标表的数据。源和目标之间不同的值将突出显示。在顶部窗格中,可以取消选中不希望应用于目标的记录。
差异选项
可以从下拉列表中选择要显示的差异类型。以下是可能的选项:
- Difference:显示源表和目标表中不同的所有记录。
- Insert:只显示目标表中不存在的记录。
- Update:只显示在具有不同值的源表和目标表中存在的记录。
- Delete:只显示源表中不存在的记录。
- Same:显示源表和目标表中具有相同值的记录。
- All Rows:显示源表和目标表中的所有记录。
在我们的例子中,选择“Update”或“Same”将显示零行,因为没有要更新的行(仅插入),并且没有相同的行:
与之前一样,单击Deploy按钮生成并显示部署脚本:
与以前的屏幕一样,此屏幕包含一个“Save Profile”按钮,允许您保存设置以备将来使用。此特定屏幕还具有一个按钮,用于保存部署脚本。
您仍然可以重新编译这两个数据库,或者继续执行部署脚本。有一个复选框用于出错时继续,以便在遇到错误时不停止部署。
当脚本执行时,您可以在消息日志中查看其进度。它显示处理的记录数和完成的百分比:
关闭对话框后,我们可以确认sakila2数据库表现在包含数据:
不要忘记保存配置文件,因为批处理作业将使用它。
点击“了解更多”下载产品最新版
↓↓↓
相关推荐
- Java中List 和 Map、Set 的区别(list和set和map)
-
hello,大家好,我是霖仔java集合的大家了解,我再给大家说一下他们的区别,希望能够帮助到大家结构特点:List和Set是存储单列数据的集合,Map是存储键和值这样的双列数据的集合;Lis...
- Java 集合框架全面解析:选对数据结构,提升开发效率
-
上一章我们详细介绍了各种常用的数据结构情况(参考:数据结构复杂度全览:如何选择最优结构?),本文结合关键数据结构,从列表(List)、队列(Queue)、集合(Set)、映射(Map)四个维度,深入解...
- LinkedList竟然比ArrayList慢了1000多倍?(动图+性能评测)
-
数组和链表是程序中常用的两种数据结构,也是面试中常考的面试题之一。然而对于很多人来说,只是模糊的记得二者的区别,可能还记得不一定对,并且每次到了面试的时候,都得把这些的概念拿出来背一遍才行,未免有些麻...
- LinkedList 底层源码深度解析(linkedlist底层数据结构)
-
目录1.引言2.LinkedList概述2.1类继承体系图2.2各个接口作用3.与ArrayList的对比4.底层数据结构5.核心方法源码解析5.1add()方法5.2a...
- List的用法和实例详解——Java进阶知识讲义系列(四)
-
序欢迎来到全网最完整的Java进阶知识系列教程!!!每天定时更新!!!本期是Java进阶知识系列的第四讲,将分享Java常用的数据容器——集合类。集合类也分很多类型,比如:List、Set、Map、Q...
- Rust高效集合操作(rust基本操作)
-
集合的分类Rust的集合类型主要分布在标准库的std::collections模块中,同时也包括语言内置的数组和字符串类型序列容器序列容器维护元素的顺序,适合需要按索引访问或顺序遍历的场景向量(...
- Java八股文:核心知识点梳理(java八股文是啥)
-
一、Java基础1.Java基本数据类型8种基本类型:整型:byte(1),short(2),int(4),long(8)浮点型:float(4),double(8)字符型:char(2)布...
- 为什么我不推荐研发人员使用 LinkedList?
-
在Java集合框架中,LinkedList作为List的实现之一,经常被认为是ArrayList的替代方案。然而,在大多数实际场景下,我们并不推荐使用LinkedList,原因主要集中...
- ArrayList 、 LinkedList、Vector的区别
-
ArrayList、LinkedList、Vector的区别如下:ArrayListLinkedListVector结构动态数组双向链表动态数组是否线程安全否否是效率遍历查找快,插入删除慢插入删除...
- (2020 )Java最新面试笔试题答案解析(一)
-
Java中的集中基本数据类型是什么?各占用多少字节?【数值型】—(整数类型)byte(1字节)short(2字节)int(4字节)long(8字节)拓展:Java中的数据类型除了上面的基本...
- 超简单五步实现Linux虚拟机CentOS 7系统Root密码忘记重置
-
环境:CentOS7.5重置root密码:1.CentOS7虚拟机开机,将鼠标光标移动至虚拟机内。2.在虚拟机中使用键盘上↑和↓键将选择行设置为第一行(背景高亮即为选中),按下键盘上的e,进...
- 吊轨门和推拉门哪个好?北京今朝区别介绍看完不入坑
-
厨房到底使用什么门好?相信这是大多数业主都比较抓狂的事情,其实在装修中材料的选择最终还是要依据空间而定,那么吊轨门和推拉门哪个好呢?下面就跟随北京装修网一起来看看吧!吊轨门与推拉门介绍吊轨门吊轨门的特...
- 〖省钱宝典〗不花冤枉钱,少走弯路!居家中推拉门如何设计?
-
想要空间最大程度的显大?想要充足的光线?又想拥有合理的区域划分?那么推拉门是你绝对不能错过的好选择。推拉门的设计轻盈简洁,绝对是室内每个空间的福音。它不仅可以最大化地节省空间,方便了居室的功能划分和利...
- 吊趟门与推拉门有什么区别?(吊趟门贵还是推拉门贵)
-
吊趟门与推拉门的区别很多人在购买的时候并不清楚,有些客人甚至根本分不清吊趟门和推拉门,今天小编就给大家讲讲吊趟门与推拉门的相关内容,看看吊趟门与推拉门的区别有哪些?1、推拉门采用以门扇下滑轮为主支撑点...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- Java中List 和 Map、Set 的区别(list和set和map)
- Java 集合框架全面解析:选对数据结构,提升开发效率
- LinkedList竟然比ArrayList慢了1000多倍?(动图+性能评测)
- LinkedList 底层源码深度解析(linkedlist底层数据结构)
- List的用法和实例详解——Java进阶知识讲义系列(四)
- Rust高效集合操作(rust基本操作)
- Java八股文:核心知识点梳理(java八股文是啥)
- 面试题:ArrayList和LinkedList有什么区别?
- 为什么我不推荐研发人员使用 LinkedList?
- ArrayList 、 LinkedList、Vector的区别
- 标签列表
-
- hive行转列函数 (63)
- sourcemap文件是什么 (54)
- display none 隐藏后怎么显示 (56)
- 共享锁和排他锁的区别 (51)
- httpservletrequest 获取参数 (64)
- jstl包 (64)
- qsharedmemory (50)
- watch computed (53)
- java中switch (68)
- date.now (55)
- git-bash (56)
- 盒子垂直居中 (68)
- npm是什么命令 (62)
- python中+=代表什么 (70)
- fsimage (51)
- nginx break (61)
- mysql分区表的优缺点 (53)
- centos7切换到图形界面 (55)
- 前端深拷贝 (62)
- kmp模式匹配算法 (57)
- jsjson字符串转json对象 (53)
- jdbc connection (61)
- javascript字符串转换为数字 (54)
- mybatis 使用 (73)
- 安装mysql数据库 (55)