可以通过sql触发器来实现。
例下列触发器代码 :
create trigger tri_kszb_inserton ygpx_kszb -- *** 作的表名
for insert --给表插入一条数据的时候触发
as
declare @kssj datetime
declare @sqbh char(40)
select @kssj = kssj,@sqbh = sqbh from inserted --把插入的数据的保存到变量
insert into ygpx_kszb2 values (@kssj,@sqbh) --同步插入到另一表
以上触发器可以实现,在表ygpx_kszb中插入数据,同步插入到表ygpx_kszb2 。
触发器还可以针对表的 insert,delete, update *** 作时安装要求执行数据同步的 *** 作,即可实现两个表里的数据同步。
同一服务器的两个库同步数据,比如同步两个库的Name字段
UPDATE bSET b[Name] = a[Name]
FROM 数据库1dboNews a
INNER JOIN 数据库2dboNews1 b ON aId = bId
不同数据库需要建立链接服务器,然后用:
UPDATE bSET b[Name] = a[Name]
FROM 数据库1dboNews a
INNER JOIN 链接服务器名称数据库2dboNews1 b ON aId = bId
这一需求在不同机器上的,
1,通过replication (master-slaves)实现了这两张表的复制功能,
2,mysql的版本是5154,基于记录的复制(Row-Based Replication)。
3,但是在备库调用存储过程时出了问题,这个存储过程中使用了UUID_short()函数,在存储过程这个函数不能产生新值。
如何对MySQL数据库中的数据进行实时同步
实现两个Mysql数据库之间同步同步原理:
MySQL 为了实现replication 必须打开bin-log 项,也是打开二进制的MySQL 日志记录选项。MySQL 的bin log 二
进制日志,可以记录所有影响到数据库表中存储记录内容的sql *** 作,如insert / update / delete *** 作,而不记录
select 这样的 *** 作。因此,我们可以通过二进制日志把某一时间段内丢失的数据可以恢复到数据库中(如果二进制日
志中记录的日志项,包涵数据库表中所有数据,那么, 就可以恢复本地数据库的全部数据了)。 而这个二进制日志,
如果用作远程数据库恢复,那就是replication 了。这就是使用replication 而不用sync 的原因。这也是为什么要设
置bin-log = 这个选项的原因。
以上就是关于sql如何将两个表里的数据同步全部的内容,包括:sql如何将两个表里的数据同步、如何实现两个数据库同步部分表的数据、如何在 MySQL 数据库之间同步数据表等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)