mysql 的table合并

来源:互联网 发布:qq for linux安装教程 编辑:程序博客网 时间:2024/05/17 11:05

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 * fromCharacterA);

只要ID不冲突,执行结果为true,可是实际插入CharacterB的数据和原来在CharacterA的数据并不一样了


那应该肿么办呢,也很简单,只要把各个字段的插入顺序固定一下就好了







原创粉丝点击