需求:ide
同一主机同实例MySQL有A和B两个库,如今需实现test1库中表host和test2库中表host插入、删除、更新单向同步。(table01与table02具备相同表结构)spa
解决方案:orm
能够使用触发器实现,举例以下:递归
一、建立模拟环境同步
create database test1;it
use test1io
CREATE TABLE `host` (table
`id` tinyint(4) NOT NULL AUTO_INCREMENT,form
`host` varchar(20) NOT NULL,class
`port` tinyint(2) NOT NULL,
`user` varchar(10) NOT NULL,
`pwd` varchar(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8
create database test2;
use test2
CREATE TABLE `host` (
`id` tinyint(4) NOT NULL AUTO_INCREMENT,
`host` varchar(20) NOT NULL,
`port` tinyint(2) NOT NULL,
`user` varchar(10) NOT NULL,
`pwd` varchar(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8
二、建立触发器(若是须要双向同步操做,在test2上进行相同操做便可,双向同步时须要注意避免递归死循环)
use test1
DELIMITER //
CREATE TRIGGER Pee_insert_host AFTER INSERT ON host FOR EACH ROW BEGIN INSERT INTO test2.host VALUES (new.id,new.host,new.port,new.user,new.pwd); END;//
CREATE TRIGGER Pee_delete_host AFTER DELETE ON host FOR EACH ROW BEGIN DELETE from test2.host where test2.host.id=old.id; END;//
CREATE TRIGGER Pee_update_host AFTER UPDATE ON host FOR EACH ROW BEGIN UPDATE test2.host SET host=new.host,port=new.port,user=new.user,pwd=new.pwd WHERE test2.host.id=new.id; END;//
DELIMITER ;
三、相关操做
查看触发器:SELECT * FROM information_schema.`TRIGGERS`;
删除触发器:DROP TRIGGER TRIGGER_NAME;