mysql怎么同步表结构的简单介绍
有2个Mysql数据库,一个本地,一个线上,需要同步两个数据库的数据。 但是数据表的结构不一样,怎么同步
1。表结构相同的表,且在同一数据库(如,table1,table2)
成都创新互联公司-专业网站定制、快速模板网站建设、高性价比阳新网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式阳新网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖阳新地区。费用合理售后完善,10多年实体公司更值得信赖。
Sql :insert into table1 select * from table2 (完全复制)
insert into table1 select distinct * from table2(不复制重复纪录)
insert into table1 select top 5 * from table2 (前五条纪录)
2。 不在同一数据库中(如,db1 table1,db2 table2)
sql: insert into db1..table1 select * from db2..table2 (完全复制)
insert into db1..table1 select distinct * from db2table2(不复制重复纪录)
insert into tdb1..able1 select top 5 * from db2table2 (前五条纪录)
mysql 如何同步部分表,求助
主上修改my.cnf文件:
server-id=1
log-bin=mysql-bin
从上修改配置文件 my.cnf
server-id=2
relay-log=replay-bin
read-only =1
replicate-ignore-db = mysql
replicate-ignore-db = test
replicate-ignore-db = information_schema
replicate-wild-do-table = mysys.channel #需要同步的一个表
replicate-wild-do-table = mysys.isp_channel #需要同步的一个表
创建 同步的用户(主上)
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* to rep@'22.2.2.22' identified by 'slave_password';
同步到主库(在从上操作)
SLAVE STOP;
reset slave;
CHANGE MASTER TO MASTER_HOST='111.11.1.11',
MASTER_USER='rep',
MASTER_PASSWORD='slave_password',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=0;
start slave;
show slave status\G
在从上验证:
mysql show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 111.11.1.11
Master_User: rep
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 593
Relay_Log_File: replay-bin.000001
Relay_Log_Pos: 730
Relay_Master_Log_File: mysql-bin.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB: mysql,test,information_schema
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table: mysys.channel,mysys.isp_channel,mysys.department,mysys.department_business,mysys.sms_key
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 593
Relay_Log_Space: 730
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: 0
1 row in set (0.00 sec)
ERROR:
No query specified
有2个数据库,怎么实现数据同步
在pgsql的数据库中将要同步的表建立一个一模一样的同步表。然后建触发器,将进入源表中的数据触发到同步表中。然后做一个windows服务扫描这个同步表并且将同步表中的数据同步到mysql
或access中。
如果是整个数据库中有许多表要进行同步。则建立一个共用的同步表,结构非常简单。字段如下:
主键(f_id),源表名(f_tablename),主键字段名(f_keyname),主键值(f_keyvalue),操作标识(f_operflag
i:插入
u:更新
d:删除),时间字段(f_time).将要同步的表都建立触发器,只要有增、改、删都触发到这个表里。这样你只扫描这个共用的同步表,根据这些字段值完全可以实现数据的同步。隔离网闸就是这么个原理,只不过它的要比这复杂多了!
如何同步数据库表结构 mysql
都是一个数据库里,直接用关联即可,
1。这样即可以省数据库空间,
2。还方便数据操作,
3。并且不要做二次数据插入!
4。而且绝对的同步!主机开两个窗口,一个进入mysql,一个是shell
--主机阻断写操作
mysql
FLUSH
TABLES
WITH
READ
LOCK;
Query
OK,
rows
affected
(0.00
sec)
mysql
mysql
mysql
SHOW
MASTER
STATUS
分享名称:mysql怎么同步表结构的简单介绍
分享地址:http://pwwzsj.com/article/dooiodi.html