0
MySQL版本5.5.27INSERT INTO ..从存储过程的错误选择了上被丢弃的列
UPDATE2:很肯定这是一个很大的,做了一个从无到有的测试与相同的行为。在MySQL网站上打开错误,并将更新结果。
更新:如果我从存储过程中的临时表中删除列,它工作正常。只有手动放下色谱柱时才会出现问题。
下面一行在存储过程中失败,出现错误:
mysql> insert into player_record_week select * from pr_temp;
mysql> call insert_agg_week('2013-02-26');
ERROR 1054 (42S22): Unknown column 'prod_gamestats.pr_temp.total_battles' in 'field list'
如果我用手它的工作原理运行。
mysql> insert into player_record_week select * from pr_temp;
Query OK, 211708 rows affected (2.23 sec)
Records: 211708 Duplicates: 0 Warnings: 0
如果我将total_battles列留在临时表中,它会失败并显示有关列数不匹配的错误。表pr_temp是通过复制player_record_week表创建的。
| insert_agg_week | | CREATE PROCEDURE `insert_agg_week`(insert_week date)
begin
delete from player_record_week where stat_week = insert_week;
delete from player_tank_record_week where stat_week = insert_week;
delete from player_ratings_week_agg where stat_week = insert_week;
delete from player_ratings_week_per where stat_week = insert_week;
delete from global_week where stat_week = insert_week;
delete from global_tank_week where stat_week = insert_week;
insert into player_record_week select * from pr_temp;
insert into player_tank_record_week select * from ptr_temp;
insert into player_ratings_week_agg select * from pratings_temp_agg;
insert into player_ratings_week_per select * from pratings_temp_per;
insert into global_week select * from global_week_temp;
insert into global_tank_week select * from global_tank_week_temp;
end | utf8 | utf8_general_ci | latin1_swedish_ci |
如果我保留额外的列,那么存储过程会出现列计数不匹配的错误。
如果我把额外的列,存储过程的错误了一起,我放弃了列的引用:
mysql> call insert_agg_week('2013-02-26');
ERROR 1054 (42S22): Unknown column 'prod_gamestats.pr_temp.total_battles' in 'field list'
如果我用手运行的命令就没有问题运行:
mysql> delete from player_record_week where stat_week = '2013-02-26';
Query OK, 0 rows affected (0.00 sec)
mysql> delete from player_tank_record_week where stat_week = '2013-02-26';
Query OK, 0 rows affected (0.00 sec)
mysql> delete from player_ratings_week_agg where stat_week = '2013-02-26';
Query OK, 0 rows affected (0.52 sec)
mysql> delete from player_ratings_week_per where stat_week = '2013-02-26';
Query OK, 0 rows affected (0.09 sec)
mysql> delete from global_week where stat_week = '2013-02-26';
Query OK, 0 rows affected (0.00 sec)
mysql> delete from global_tank_week where stat_week = '2013-02-26';
Query OK, 0 rows affected (0.00 sec)
mysql> insert into player_record_week select * from pr_temp;
Query OK, 211708 rows affected (2.23 sec)
Records: 211708 Duplicates: 0 Warnings: 0
mysql> insert into player_tank_record_week select * from ptr_temp;
Query OK, 1618240 rows affected (25.61 sec)
Records: 1618240 Duplicates: 0 Warnings: 0
mysql> insert into player_ratings_week_agg select * from pratings_temp_agg;
Query OK, 211708 rows affected (1.86 sec)
Records: 211708 Duplicates: 0 Warnings: 0
mysql> insert into player_ratings_week_per select * from pratings_temp_per;
Query OK, 41648 rows affected (0.39 sec)
Records: 41648 Duplicates: 0 Warnings: 0
mysql> insert into global_week select * from global_week_temp;
Query OK, 21 rows affected (0.00 sec)
Records: 21 Duplicates: 0 Warnings: 0
mysql> insert into global_tank_week select * from global_tank_week_temp;
Query OK, 257 rows affected (0.00 sec)
Records: 257 Duplicates: 0 Warnings: 0
下面是两个表:
mysql> describe pr_temp;
+------------------------+-----------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+------------------------+-----------------------+------+-----+---------+-------+
| player_id | int(10) unsigned | NO | PRI | NULL | |
| stat_week | date | NO | PRI | NULL | |
| insert_date | date | NO | | NULL | |
| tier_weight | float | YES | | 0 | |
| tier_weight_adj | float | YES | | 0 | |
| battles_count | int(10) unsigned | YES | | NULL | |
| wins | mediumint(8) unsigned | YES | | NULL | |
| losses | mediumint(8) unsigned | YES | | NULL | |
| survived_battles | mediumint(8) unsigned | YES | | NULL | |
| spotted | mediumint(8) unsigned | YES | | NULL | |
| hits_percents | tinyint(3) unsigned | YES | | NULL | |
| capture_points | mediumint(8) unsigned | YES | | NULL | |
| damage_dealt | int(10) unsigned | YES | | NULL | |
| frags | mediumint(8) unsigned | YES | | NULL | |
| dropped_capture_points | mediumint(8) unsigned | YES | | NULL | |
| max_xp | smallint(5) unsigned | YES | | NULL | |
| battle_avg_xp | smallint(5) unsigned | YES | | NULL | |
| xp | int(10) unsigned | YES | | NULL | |
| integrated_rating | smallint(5) unsigned | YES | | NULL | |
| efficiency | smallint(6) | YES | | NULL | |
| efficiency_adj | smallint(6) | YES | | NULL | |
| wn7 | smallint(6) | YES | | NULL | |
| wn7_adj | smallint(6) | YES | | NULL | |
+------------------------+-----------------------+------+-----+---------+-------+
23 rows in set (0.00 sec)
mysql> describe player_record_week;
+------------------------+-----------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+------------------------+-----------------------+------+-----+---------+-------+
| player_id | int(10) unsigned | NO | PRI | NULL | |
| stat_week | date | NO | PRI | NULL | |
| insert_date | date | NO | | NULL | |
| tier_weight | float | YES | | 0 | |
| tier_weight_adj | float | YES | | 0 | |
| battles_count | int(10) unsigned | YES | | NULL | |
| wins | mediumint(8) unsigned | YES | | NULL | |
| losses | mediumint(8) unsigned | YES | | NULL | |
| survived_battles | mediumint(8) unsigned | YES | | NULL | |
| spotted | mediumint(8) unsigned | YES | | NULL | |
| hits_percents | tinyint(3) unsigned | YES | | NULL | |
| capture_points | mediumint(8) unsigned | YES | | NULL | |
| damage_dealt | int(10) unsigned | YES | | NULL | |
| frags | mediumint(8) unsigned | YES | | NULL | |
| dropped_capture_points | mediumint(8) unsigned | YES | | NULL | |
| max_xp | smallint(5) unsigned | YES | | NULL | |
| battle_avg_xp | smallint(5) unsigned | YES | | NULL | |
| xp | int(10) unsigned | YES | | NULL | |
| integrated_rating | smallint(5) unsigned | YES | | NULL | |
| efficiency | smallint(6) | YES | | NULL | |
| efficiency_adj | smallint(6) | YES | | NULL | |
| wn7 | smallint(6) | YES | | NULL | |
| wn7_adj | smallint(6) | YES | | NULL | |
+------------------------+-----------------------+------+-----+---------+-------+
23 rows in set (0.00 sec)