| Bug #43046 | mixed mode switch to row format with temp table lead to wrong result | ||
|---|---|---|---|
| Submitted: | 20 Feb 2009 8:40 | Modified: | 5 Aug 2009 11:21 | 
| Reporter: | li zhou | Email Updates: | |
| Status: | Closed | Impact on me: | |
| Category: | MySQL Server: Replication | Severity: | S2 (Serious) | 
| Version: | 5.1.26+, 5.1, 6.0 bzr | OS: | Any | 
| Assigned to: | Luis Soares | CPU Architecture: | Any | 
| Tags: | temporary tables mixed row | ||
   [20 Feb 2009 8:40]
   li zhou        
  
 
   [2 Jul 2009 20:35]
   Bugs System        
  A patch for this bug has been committed. After review, it may be pushed to the relevant source trees for release in the next version. You can access the patch from: http://lists.mysql.com/commits/77829 3357 Luis Soares 2009-07-02 BUG#43046: mixed mode switch to row format with temp table lead to wrong result When using MIXED mode and issuing 'CREATE TEMPORARY TABLE t_tmp', the statement is logged if the current binlogging mode is STATEMENT. This causes the slave to replay the instruction and create the temporary table as well. If there is no switch to ROW mode, and later on a 'DROP TEMPORARY TABLE t_tmp' is issued, then this statement will also be logged and the slave will remove/close the temporary table. However, if there is a switch to ROW mode between the CREATE and DROP TEMPORARY table, the DROP statement will not be logged, leaving the slave with a dangling temporary table. This patch addresses this, by always logging a DROP TEMPORARY TABLE IF EXISTS when in mixed mode and a drop statement is issued for temporary table(s). @ mysql-test/suite/rpl/r/rpl_temp_table_mix_row.result Updated result file. @ mysql-test/suite/rpl/t/rpl_temp_table_mix_row.test Added test case. @ sql/sql_table.cc When dropping table(s) in mixed mode and current statement logging is ROW, builds an extra DROP TEMPORARY TABLE IF EXISTS for temporary tables that are being dropped. Later, it logs the extra drop statement.
   [8 Jul 2009 13:02]
   Bugs System        
  A patch for this bug has been committed. After review, it may be pushed to the relevant source trees for release in the next version. You can access the patch from: http://lists.mysql.com/commits/78206 3357 Luis Soares 2009-07-08 BUG#43046: mixed mode switch to row format with temp table lead to wrong result When using MIXED mode and issuing 'CREATE TEMPORARY TABLE t_tmp', the statement is logged if the current binlogging mode is STATEMENT. This causes the slave to replay the instruction and create the temporary table as well. If there is no switch to ROW mode, and later on a 'DROP TEMPORARY TABLE t_tmp' is issued, then this statement will also be logged and the slave will remove/close the temporary table. However, if there is a switch to ROW mode between the CREATE and DROP TEMPORARY table, the DROP statement will not be logged, leaving the slave with a dangling temporary table. This patch addresses this, by always logging a DROP TEMPORARY TABLE IF EXISTS when in mixed mode and a drop statement is issued for temporary table(s). @ mysql-test/suite/rpl/r/rpl_temp_table_mix_row.result Updated result file. @ mysql-test/suite/rpl/t/rpl_temp_table_mix_row.test Added test case. @ sql/sql_table.cc When dropping table(s) in mixed mode and current statement logging is ROW, builds an extra DROP TEMPORARY TABLE IF EXISTS for temporary tables that are being dropped. Later, it logs the extra drop statement.
   [26 Jul 2009 21:49]
   Bugs System        
  A patch for this bug has been committed. After review, it may be pushed to the relevant source trees for release in the next version. You can access the patch from: http://lists.mysql.com/commits/79298 3043 Luis Soares 2009-07-26 BUG#43046: mixed mode switch to row format with temp table lead to wrong result When using MIXED mode and issuing 'CREATE TEMPORARY TABLE t_tmp', the statement is logged if the current binlogging mode is STATEMENT. This causes the slave to replay the instruction and create the temporary table as well. If there is no switch to ROW mode, and later on a 'DROP TEMPORARY TABLE t_tmp' is issued, then this statement will also be logged and the slave will remove/close the temporary table. However, if there is a switch to ROW mode between the CREATE and DROP TEMPORARY table, the DROP statement will not be logged, leaving the slave with a dangling temporary table. This patch addresses this, by always logging a DROP TEMPORARY TABLE IF EXISTS when in mixed mode and a drop statement is issued for temporary table(s). @ mysql-test/suite/rpl/r/rpl_temp_table_mix_row.result Updated result file. @ mysql-test/suite/rpl/t/rpl_temp_table_mix_row.test Added test case. @ sql/sql_table.cc When dropping table(s) in mixed mode and current statement logging is ROW, builds an extra DROP TEMPORARY TABLE IF EXISTS for temporary tables that are being dropped. Later, it logs the extra drop statement.
   [26 Jul 2009 22:04]
   Bugs System        
  A patch for this bug has been committed. After review, it may be pushed to the relevant source trees for release in the next version. You can access the patch from: http://lists.mysql.com/commits/79299 3486 Luis Soares 2009-07-26 [merge] BUG#43046: mixed mode switch to row format with temp table lead to wrong result Automerge: mysql-5.1-bugteam --> mysql-pe
   [26 Jul 2009 22:35]
   Luis Soares        
  Pushed to mysql-5.1-bugteam and mysql-pe.
   [4 Aug 2009 19:51]
   Bugs System        
  Pushed into 5.4.4-alpha (revid:alik@sun.com-20090804194615-h40sa098mx4z49qg) (version source revid:satya.bn@sun.com-20090727062228-uf93hg5izc1lpe3z) (merge vers: 5.4.4-alpha) (pib:11)
   [4 Aug 2009 20:45]
   Bugs System        
  Pushed into 5.1.38 (revid:davi.arnaut@sun.com-20090804204317-ggodqkik7de6nfpz) (version source revid:davi.arnaut@sun.com-20090804204317-ggodqkik7de6nfpz) (merge vers: 5.1.38) (pib:11)
   [5 Aug 2009 11:21]
   Jon Stephens        
  Documented bugfix in the 5.1.38 and 5.4.4 changelogs, as follows:
        When using the MIXED logging format, after creating a temporary
        table and performing an update that switched the logging format
        to ROW, the format switch persisted following the update,
        preventing any subsequent DDL statements on temporary tables
        from being written to the binary log until the temporary table
        was dropped.
 
   [12 Aug 2009 22:03]
   Paul DuBois        
  Noted in 5.4.2 changelog because next 5.4 version will be 5.4.2 and not 5.4.4.
   [14 Aug 2009 22:55]
   Paul DuBois        
  Ignore previous comment about 5.4.2.
   [1 Oct 2009 5:59]
   Bugs System        
  Pushed into 5.1.39-ndb-6.3.28 (revid:jonas@mysql.com-20091001055605-ap2kiaarr7p40mmv) (version source revid:jonas@mysql.com-20091001055605-ap2kiaarr7p40mmv) (merge vers: 5.1.39-ndb-6.3.28) (pib:11)
   [1 Oct 2009 7:25]
   Bugs System        
  Pushed into 5.1.39-ndb-7.0.9 (revid:jonas@mysql.com-20091001072547-kv17uu06hfjhgjay) (version source revid:jonas@mysql.com-20091001071652-irejtnumzbpsbgk2) (merge vers: 5.1.39-ndb-7.0.9) (pib:11)
   [1 Oct 2009 13:25]
   Bugs System        
  Pushed into 5.1.39-ndb-7.1.0 (revid:jonas@mysql.com-20091001123013-g9ob2tsyctpw6zs0) (version source revid:jonas@mysql.com-20091001123013-g9ob2tsyctpw6zs0) (merge vers: 5.1.39-ndb-7.1.0) (pib:11)
   [5 Oct 2009 10:50]
   Bugs System        
  Pushed into 5.1.39-ndb-6.2.19 (revid:jonas@mysql.com-20091005103850-dwij2dojwpvf5hi6) (version source revid:jonas@mysql.com-20090930185117-bhud4ek1y0hsj1nv) (merge vers: 5.1.39-ndb-6.2.19) (pib:11)
   [7 Oct 2009 1:50]
   Paul DuBois        
  The 5.4 fix has been pushed into 5.4.2.

