| Bug #55777 | CREATE TABLE..SELECT doesn't throw error when view with same name exists | ||
|---|---|---|---|
| Submitted: | 5 Aug 2010 11:19 | Modified: | 15 Oct 2010 14:12 | 
| Reporter: | Nidhi Shrotriya | Email Updates: | |
| Status: | Closed | Impact on me: | |
| Category: | MySQL Server | Severity: | S3 (Non-critical) | 
| Version: | 5.1-wl5370 | OS: | Any | 
| Assigned to: | Libing Song | CPU Architecture: | Any | 
   [5 Aug 2010 11:19]
   Nidhi Shrotriya        
  
 
   [10 Aug 2010 9:46]
   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/115381 3477 Li-Bing.Song@sun.com 2010-08-10 Bug#55777 CREATE TABLE..SELECT doesn't throw error when view with same name exist The statement always throws a warning when the table of the same name exists. After this patch, It throws an error if there is no 'IF NOT EXISTS' option, but throw a warning when 'IF NOT EXISTS' option appears.
   [11 Aug 2010 9:17]
   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/115461 3477 Li-Bing.Song@sun.com 2010-08-11 Bug#55777 CREATE TABLE..SELECT doesn't throw error when view with same name exist The statement always throws a warning when the table of the same name exists. After this patch, It throws an error if there is no 'IF NOT EXISTS' option, but throw a warning when 'IF NOT EXISTS' option appears.
   [17 Aug 2010 13:01]
   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/115957 3479 Li-Bing.Song@sun.com 2010-08-17 WL#5370 Keep forward-compatibility when changing 'CREATE TABLE IF NOT EXISTS ... SELECT' behaviour BUG#55474, BUG#55499, BUG#55598, BUG#55616 and BUG#55777 are fixed in this patch too. This is the 5.1 part. It implements: - if the table exists, binlog two events: CREATE TABLE IF NOT EXISTS and INSERT ... SELECT - Insert nothing and binlog nothing on master if the existing object is a view. It only generates a warning that table already exists. @ sql/sql_class.h Declare virtual function write_to_binlog() for select_insert. It's used to binlog 'create select' @ sql/sql_insert.cc Implement write_to_binlog(); Use write_to_binlog() instead of binlog_query() to binlog the statement. if the table exists, binlog two events: CREATE TABLE IF NOT EXISTS and INSERT ... SELECT @ sql/sql_lex.h Declare create_select_start_with_brace and create_select_pos. They are helpful for binlogging 'create select' @ sql/sql_parse.cc Do nothing on master if the existing object is a view. @ sql/sql_yacc.yy Record the relative postion of 'SELECT' in the 'CREATE ...SELECT' statement. Record whether there is a '(' before the 'SELECT' clause.
   [18 Aug 2010 4:58]
   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/116025 3484 Li-Bing.Song@sun.com 2010-08-18 WL#5370 Keep forward-compatibility when changing 'CREATE TABLE IF NOT EXISTS ... SELECT' behaviour BUG#55474, BUG#55499, BUG#55598, BUG#55616 and BUG#55777 are fixed in this patch too. This is the 5.1 part. It implements: - if the table exists, binlog two events: CREATE TABLE IF NOT EXISTS and INSERT ... SELECT - Insert nothing and binlog nothing on master if the existing object is a view. It only generates a warning that table already exists. @ mysql-test/r/trigger.result Ather this patch, 'CREATE TABLE IF NOT EXISTS ... SELECT' will not insert anything if the creating table already exists and is a view. @ sql/sql_class.h Declare virtual function write_to_binlog() for select_insert. It's used to binlog 'create select' @ sql/sql_insert.cc Implement write_to_binlog(); Use write_to_binlog() instead of binlog_query() to binlog the statement. if the table exists, binlog two events: CREATE TABLE IF NOT EXISTS and INSERT ... SELECT @ sql/sql_lex.h Declare create_select_start_with_brace and create_select_pos. They are helpful for binlogging 'create select' @ sql/sql_parse.cc Do nothing on master if the existing object is a view. @ sql/sql_yacc.yy Record the relative postion of 'SELECT' in the 'CREATE ...SELECT' statement. Record whether there is a '(' before the 'SELECT' clause.
   [19 Aug 2010 7:42]
   Libing Song        
  It was fixed in the final patch for WL#5370.
   [25 Aug 2010 10:24]
   Bugs System        
  Pushed into mysql-5.5 5.5.6-m3 (revid:alik@ibmvm-20100825102234-a3q8x0l7voa13ts3) (version source revid:alik@ibmvm-20100825102234-a3q8x0l7voa13ts3) (merge vers: 5.5.6-m3) (pib:20)
   [1 Sep 2010 13:13]
   Bugs System        
  Pushed into mysql-trunk 5.6.1-m4 (revid:alik@sun.com-20100901130501-4g2k86dub29auj8y) (version source revid:alik@sun.com-20100901130012-9bmmvzcnnw6n5rw6) (merge vers: 5.6.1-m4) (pib:21)
   [1 Sep 2010 13:15]
   Bugs System        
  Pushed into mysql-next-mr (revid:alik@sun.com-20100901130614-pgop3m80rmutewxn) (version source revid:alik@sun.com-20100901130033-8k19cjn6n2blm3py) (pib:21)
   [3 Sep 2010 18:51]
   Paul DuBois        
  Noted in 5.1.51, 5.5.7 changelogs. If a view was named as the destination table for CREATE TABLE ... SELECT, the server produced a warning whether or not IF NOT EXISTS was used. Now it produces a warning only when IF NOT EXISTS is used, and and error otherwise.
   [28 Sep 2010 8:49]
   Bugs System        
  Pushed into mysql-5.1 5.1.52 (revid:sunanda.menon@sun.com-20100928083322-wangbv97uobu7g66) (version source revid:sunanda.menon@sun.com-20100928083322-wangbv97uobu7g66) (merge vers: 5.1.52) (pib:21)
   [14 Oct 2010 8:39]
   Bugs System        
  Pushed into mysql-5.1-telco-7.0 5.1.51-ndb-7.0.20 (revid:martin.skold@mysql.com-20101014082627-jrmy9xbfbtrebw3c) (version source revid:martin.skold@mysql.com-20101014082627-jrmy9xbfbtrebw3c) (merge vers: 5.1.51-ndb-7.0.20) (pib:21)
   [14 Oct 2010 8:54]
   Bugs System        
  Pushed into mysql-5.1-telco-6.3 5.1.51-ndb-6.3.39 (revid:martin.skold@mysql.com-20101014083757-5qo48b86d69zjvzj) (version source revid:martin.skold@mysql.com-20101014083757-5qo48b86d69zjvzj) (merge vers: 5.1.51-ndb-6.3.39) (pib:21)
   [14 Oct 2010 9:11]
   Bugs System        
  Pushed into mysql-5.1-telco-6.2 5.1.51-ndb-6.2.19 (revid:martin.skold@mysql.com-20101014084420-y54ecj85j5we27oa) (version source revid:martin.skold@mysql.com-20101014084420-y54ecj85j5we27oa) (merge vers: 5.1.51-ndb-6.2.19) (pib:21)
   [15 Oct 2010 14:12]
   Jon Stephens        
  Already documented in the 5.1.51 changelog; reverted to Closed state.

