mysql 的table合併

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的數據並不一樣了


那應該腫麼辦呢,也很簡單,只要把各個字段的插入順序固定一下就好了







發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章