| Bug #22372 | Disable spatial key, load data, enable spatial key, crashes table | ||
|---|---|---|---|
| Submitted: | 15 Sep 2006 0:12 | Modified: | 13 Dec 2006 18:57 | 
| Reporter: | Peter Brodersen (Candidate Quality Contributor) | Email Updates: | |
| Status: | Closed | Impact on me: | |
| Category: | MySQL Server | Severity: | S2 (Serious) | 
| Version: | 5.1.12-beta-log, 5.0.24a-Debian_2.dotdeb, 5.0 BK, 4.1 BK | OS: | Linux (linux) | 
| Assigned to: | Alexey Botchkov | CPU Architecture: | Any | 
   [15 Sep 2006 0:12]
   Peter Brodersen        
  
 
   [15 Sep 2006 11:30]
   Sveta Smirnova        
  Thank you for the report. Verified as described on Linux. All versions are affected.
   [7 Oct 2006 16:11]
   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/13293 ChangeSet@1.2574, 2006-10-07 21:39:10+05:00, holyfoot@mysql.com +5 -0 bug #22372 (LOAD DATA crashes the table with the GEOMETRY field) The problem is that the GEOMETRY field doesn't have and default value that is usually set by Field::reset method, if the field can't be NULL. So if the loaded file doesn't have all the data it can't be loaded. I propose to check if the 'reset' operation is possible for the field and return an error if it's not.
   [26 Oct 2006 11:52]
   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/14424 ChangeSet@1.2574, 2006-10-26 17:23:14+05:00, holyfoot@mysql.com +4 -0 bug #22372 (LOAD DATA crashes the table with the GEOMETRY field) The problem is that the GEOMETRY field doesn't have and default value that is usually set by Field::reset method, if the field can't be NULL. So if the loaded file doesn't have all the data it can't be loaded. I propose to check if the 'reset' operation is possible for the field and return an error if it's not.
   [26 Oct 2006 12:01]
   Alexander Barkov        
  The patch "bk commit into 4.1 tree (holyfoot:1.2574) BUG#22372" is ok to push. P.S. Consider extending the test to load a file with multiple records, with good records in the beginning and a bad record in the middle.
   [26 Oct 2006 12:17]
   Alexander Barkov        
  Sorry, previous patch was incomplete. We not should change behaviour for non-GEOMETRY fields. Please add condition: (field->type() == FIELD_TYPE_GEOMETRY) and post a new patch.
   [26 Oct 2006 12: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/14428 ChangeSet@1.2574, 2006-10-26 18:12:53+05:00, holyfoot@mysql.com +4 -0 bug #22372 (LOAD DATA crashes the table with the GEOMETRY field) The problem is that the GEOMETRY field doesn't have and default value that is usually set by Field::reset method, if the field can't be NULL. So if the loaded file doesn't have all the data it can't be loaded. I propose to check if the 'reset' operation is possible for the field and return an error if it's not.
   [26 Oct 2006 13: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/14430 ChangeSet@1.2574, 2006-10-26 19:25:45+05:00, holyfoot@mysql.com +4 -0 bug #22372 (LOAD DATA crashes the table with the GEOMETRY field) The problem is that the GEOMETRY field doesn't have and default value that is usually set by Field::reset method, if the field can't be NULL. So if the loaded file doesn't have all the data it can't be loaded. I propose to check if the 'reset' operation is possible for the field and return an error if it's not.
   [30 Oct 2006 6:03]
   Alexander Barkov        
  The patch "bk commit into 4.1 tree (holyfoot:1.2574) BUG#22372" is ok. One thing: I'd still recommend to extend tests to load a file with several lines, with a bad line in the middle.
   [2 Dec 2006 14:48]
   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/16352 ChangeSet@1.2557, 2006-12-02 19:22:15+04:00, holyfoot@mysql.com +5 -0 bug #22372 (LOAD DATA crashes the table with the geometry field) The problem is that the GEOMETRY NOT NULL can't automatically set any value as a default one. Now we always complete LOAD DATA command, even if we don't have all the data in file. That doesn't work for the GEOMETRY field. Setting the 'default' value for the field ordinarily is done by Field::reset method. Now it returns an error if Field can't be reset.
   [2 Dec 2006 14: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/16353 ChangeSet@1.2558, 2006-12-02 19:23:56+04:00, holyfoot@mysql.com +1 -0 bug #22372 (LOAD DATA on GEOMETRY crashes server) Required bad_gis_data.dat added to be used in test
   [6 Dec 2006 17:11]
   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/16531 ChangeSet@1.2563, 2006-12-06 21:45:57+04:00, holyfoot@mysql.com +5 -0 bug #22372 (LOAD DATA crashes the table with the geometry field) The problem is that the GEOMETRY NOT NULL can't automatically set any value as a default one. We always tried to complete LOAD DATA command even if there's not enough data in file. That doesn't work for GEOMETRY NOT NULL. Now Field_*::reset() returns an error sign and it's checked in mysql_load()
   [6 Dec 2006 17:13]
   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/16532 ChangeSet@1.2564, 2006-12-06 21:47:29+04:00, holyfoot@mysql.com +1 -0 bug #22372 datafile added to be used in gis.test
   [13 Dec 2006 12:31]
   Sergei Glukhov        
  Fixed in 4.1.23, merged to 5.0.32, 5.1.15-beta
   [13 Dec 2006 18:57]
   Paul DuBois        
  Noted in 4.1.23, 5.0.32, 5.1.15 changelogs. A server crash occurred when using LOAD DATA to load a table containing a NOT NULL spatial column, when the statement did not load the spatial column. Now a NULL supplied to NOT NULL column error occurs.

