mysql 在合并2个表格的时候没有检查2个表格字段是否一致,这回导致合并后的数据与原来的出现很大差异
比如有2个表
`CharacterA`(
`ID` int(10) unsigned NOT NULL,
`NAME` varchar(32) CHARACTER SET latin1 NOT NULL,
`LEVEL` tinyint(3) unsigned NOT NULL,
`HP` int(10) unsigned NOT NULL,
`MP` int(10) unsigned NOT NULL,
PRIMARY KEY (`ID`)
);
`CharacterB`(
`ID` int(10) unsigned NOT NULL,
`NAME` varchar(32) CHARACTER SET latin1 NOT NULL,
`MP` int(10) unsigned NOT NULL,
`HP` int(10) unsigned NOT NULL,
`LEVEL` tinyint(3) unsigned NOT NULL,
PRIMARY KEY (`ID`)
);
这俩个表的字段都是一样的,只是各字段的顺序不同,如果执行以下操作:
insert into CharacterB (select * from CharacterA);
只要ID不冲突,执行结果为true,可是实际插入CharacterB的数据和原来在CharacterA的数据并不一样了
那应该肿么办呢,也很简单,只要把各个字段的插入顺序固定一下就好了