| Bug #36055 | mysql_upgrade doesn't really 'upgrade' tables | ||
|---|---|---|---|
| Submitted: | 14 Apr 2008 11:53 | Modified: | 22 May 2008 15:56 | 
| Reporter: | Victoria Reznichenko | Email Updates: | |
| Status: | Closed | Impact on me: | |
| Category: | MySQL Server: Command-line Clients | Severity: | S2 (Serious) | 
| Version: | all | OS: | Any | 
| Assigned to: | Gleb Shchepa | CPU Architecture: | Any | 
   [14 Apr 2008 11:53]
   Victoria Reznichenko        
  
 
   [5 May 2008 19:42]
   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/46368 ChangeSet@1.2614, 2008-05-06 00:40:38+05:00, gshchepa@host.loc +2 -0 Fixed bug #36055: mysql_upgrade doesn't really 'upgrade' tables The REPAIR TABLE ... USE_FRM query silently corrupts data of tables with old .FRM file version. The mysql_upgrade client program or the REPAIR TABLE query (without the USE_FRM clause) can't prevent this trouble, because in the common case they don't upgrade .FRM file to compatible structure. 1. Evaluation of the REPAIR TABLE ... USE_FRM query has been modified to reject such tables with the message: "Failed repairing incompatible .FRM file". 2. REPAIR TABLE query (without USE_FRM clause) evaluation has been modified to upgrade .FRM files to current version. 3. CHECK TABLE ... FOR UPGRADE query evaluation has been modified to return error status when .FRM file has incompatible version. 4. mysql_upgrade and mysqlcheck client programs call CHECK TABLE FOR UPGRADE and REPAIR TABLE queries, so their behaviors have been changed too to upgrade .FRM files with incompatible version numbers.
   [12 May 2008 16: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/46629 ChangeSet@1.2614, 2008-05-12 21:01:13+05:00, gshchepa@host.loc +7 -0 Fixed bug #36055: mysql_upgrade doesn't really 'upgrade' tables The REPAIR TABLE ... USE_FRM query silently corrupts data of tables with old .FRM file version. The mysql_upgrade client program or the REPAIR TABLE query (without the USE_FRM clause) can't prevent this trouble, because in the common case they don't upgrade .FRM file to compatible structure. 1. Evaluation of the REPAIR TABLE ... USE_FRM query has been modified to reject such tables with the message: "Failed repairing incompatible .FRM file". 2. REPAIR TABLE query (without USE_FRM clause) evaluation has been modified to upgrade .FRM files to current version. 3. CHECK TABLE ... FOR UPGRADE query evaluation has been modified to return error status when .FRM file has incompatible version. 4. mysql_upgrade and mysqlcheck client programs call CHECK TABLE FOR UPGRADE and REPAIR TABLE queries, so their behaviors have been changed too to upgrade .FRM files with incompatible version numbers.
   [12 May 2008 18:41]
   Alexey Botchkov        
  Ok to push.
   [14 May 2008 15:19]
   Bugs System        
  Pushed into 5.0.62
   [14 May 2008 15:21]
   Bugs System        
  Pushed into 5.1.25-rc
   [20 May 2008 16:51]
   Paul DuBois        
  Noted in 5.0.62, 5.1.25 changelogs.
Some changes were made to CHECK TABLE ... FOR UPGRADE and REPAIR
TABLE with respect to detection and handling of tables with
incompatible .frm files (files created with a different version of
the MySQL server). These changes also affect mysqlcheck because that
program uses CHECK TABLE and REPAIR table, and thus also
mysql_upgrade because that program invokes mysqlcheck.
      
- If your table was created by a different version of the MySQL server
than the one you are currently running, CHECK TABLE ... FOR UPGRADE
indicates that the table has an .frm file with an incompatible
version. In this case, the result set returned by CHECK TABLE
contains a line with a Msg_type value of error and a Msg_text value
of Table upgrade required. Please do "REPAIR TABLE `tbl_name`" to fix
it!     
      
- REPAIR TABLE without USE_FRM upgrades the .frm file to the current
version. 
        
- If you use REPAIR TABLE ...USE_FRM and your table was created by a
different version of the MySQL server than the one you are currently
running, REPAIR TABLE will not attempt to repair the table. In this
case, the result set returned by REPAIR TABLE contains a line with a
Msg_type value of error and a Msg_text value of Failed reparing
incompatible .FRM file.
Previously, use of REPAIR TABLE ...USE_FRM with a table created by a 
different version of the MySQL server risked the loss of all rows in
the table.  
Setting report to Need Doc Info pending push into 6.0.x.
 
   [20 May 2008 22:34]
   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/46899 ChangeSet@1.2632, 2008-05-20 23:49:52+02:00, gshchepa@devsrv-b.mysql.com +2 -0 repair.result, sql_table.cc: Bug#36055: minor post-commit fix of typo in error message text.
   [22 May 2008 9:51]
   Bugs System        
  Pushed into 6.0.6-alpha
   [22 May 2008 15:56]
   Paul DuBois        
  Noted in 6.0.6 changelog.
   [18 Jun 2008 10:05]
   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/48060 2656 Sven Sandberg 2008-06-12 [merge] Merge of the following in 6.0-rpl: pull from main and bug number 37200
   [18 Jun 2008 10:09]
   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/48061 2656 Sven Sandberg 2008-06-12 [merge] Merge of the following in 6.0-rpl: pull from main and bug number 37200
   [18 Jun 2008 10:22]
   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/48064 2656 Sven Sandberg 2008-06-12 [merge] Merge of the following in 6.0-rpl: pull from main and bug number 37200
   [10 Aug 2008 18:55]
   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/51259 2656 jonas@mysql.com 2008-08-10 [merge] merge
   [28 Aug 2008 11:00]
   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/52829

