mirror of
https://github.com/MariaDB/server.git
synced 2025-12-24 11:21:21 +03:00
Fixes for CREATE_OR_REPLACE
- MDEV-5587 Server crashes in Locked_tables_list::restore_lock on CREATE OR REPLACE .. SELECT under LOCK - MDEV-5586 Assertion `share->tdc.all_tables.is_empty() || remove_type != TDC_RT_REMOVE_ALL' fails in tdc_remove_table - MDEV-5588 Strange error on CREATE OR REPLACE table over an existing view mysql-test/r/create_or_replace.result: Added test cases mysql-test/r/lowercase_view.result: New error message mysql-test/r/merge.result: New error message mysql-test/r/multi_update.result: New error message mysql-test/r/subselect.result: New error message mysql-test/r/subselect_exists_to_in.result: New error message mysql-test/r/subselect_no_mat.result: New error message mysql-test/r/subselect_no_opts.result: New error message mysql-test/r/subselect_no_scache.result: New error message mysql-test/r/subselect_no_semijoin.result: New error message mysql-test/r/view.result: New error message mysql-test/suite/funcs_1/r/myisam_views-big.result: New error message mysql-test/t/create_or_replace.test: New tests mysql-test/t/view.test: New error message sql/share/errmsg-utf8.txt: Added new error message sql/sql_base.cc: Updated error message Do an automatic UNLOCK TABLES if we don't have any locked tables (safety fix) sql/sql_db.cc: Updated arguments sql/sql_load.cc: New error message sql/sql_parse.cc: Check that we are not using a table we are dropping and re-creating sql/sql_table.cc: Added parameter to mysql_rm_table_no_locks() to not automaticly do UNLOCK TABLES Added better error message if trying to drop a view with DROP TABLE Don't try to create something we select from sql/sql_table.h: Updated prototypes
This commit is contained in:
@@ -4,7 +4,7 @@
|
||||
|
||||
--source include/have_innodb.inc
|
||||
--disable_warnings
|
||||
drop table if exists t1,t2;
|
||||
drop table if exists t1,t2,t3;
|
||||
--enable_warnings
|
||||
|
||||
#
|
||||
@@ -90,10 +90,21 @@ SHOW CREATE TABLE t1;
|
||||
DROP TABLE t1;
|
||||
CREATE TEMPORARY TABLE t1 AS SELECT a FROM t2;
|
||||
CREATE TEMPORARY TABLE IF NOT EXISTS t1(a int, b int) SELECT 1,2 FROM t2;
|
||||
create or replace table t1 as select 1;
|
||||
show create table t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 (a int);
|
||||
CREATE OR REPLACE TABLE t1 AS SELECT 1;
|
||||
SHOW CREATE TABLE t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
create table t1 (a int);
|
||||
--error ER_UPDATE_TABLE_USED
|
||||
create or replace table t1 as select * from t1;
|
||||
--error ER_UPDATE_TABLE_USED
|
||||
create or replace table t1 as select a from (select a from t1) as t3;
|
||||
--error ER_UPDATE_TABLE_USED
|
||||
create or replace table t1 as select a from t2 where t2.a in (select a from t1);
|
||||
drop table t1;
|
||||
|
||||
--echo #
|
||||
--echo # Testing with normal tables
|
||||
@@ -156,6 +167,14 @@ SELECT * FROM t1 as t1_read;
|
||||
DROP TABLE t1;
|
||||
UNLOCK TABLES;
|
||||
|
||||
CREATE OR REPLACE TABLE t1 (a int);
|
||||
LOCK TABLE t1 WRITE;
|
||||
CREATE OR REPLACE TABLE t1 AS SELECT 1;
|
||||
SELECT * from t1;
|
||||
--error ER_TABLE_NOT_LOCKED
|
||||
SELECT * from t2;
|
||||
DROP TABLE t1;
|
||||
|
||||
--echo #
|
||||
--echo # Test also with InnoDB (transactional engine)
|
||||
--echo #
|
||||
@@ -201,6 +220,24 @@ unlock tables;
|
||||
show create table t1;
|
||||
drop table t1;
|
||||
|
||||
create or replace table t1 like t2;
|
||||
--error ER_NONUNIQ_TABLE
|
||||
create or replace table t1 like t1;
|
||||
drop table t1;
|
||||
|
||||
CREATE TEMPORARY TABLE t1 like t2;
|
||||
--error ER_NONUNIQ_TABLE
|
||||
CREATE OR REPLACE TABLE t1 like t1;
|
||||
--error ER_NONUNIQ_TABLE
|
||||
CREATE OR REPLACE TABLE t1 like t1;
|
||||
drop table t1;
|
||||
|
||||
CREATE TEMPORARY TABLE t1 like t2;
|
||||
CREATE OR REPLACE TEMPORARY TABLE t3 like t1;
|
||||
--error ER_NONUNIQ_TABLE
|
||||
CREATE OR REPLACE TEMPORARY TABLE t3 like t3;
|
||||
drop table t1,t3;
|
||||
|
||||
--echo #
|
||||
--echo # Test with prepared statements
|
||||
--echo #
|
||||
@@ -222,9 +259,9 @@ drop table t1;
|
||||
|
||||
create view t1 as select 1;
|
||||
create table if not exists t1 (a int);
|
||||
--error ER_BAD_TABLE_ERROR
|
||||
--error ER_IT_IS_A_VIEW
|
||||
create or replace table t1 (a int);
|
||||
--error ER_BAD_TABLE_ERROR
|
||||
--error ER_IT_IS_A_VIEW
|
||||
drop table t1;
|
||||
drop view t1;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user