mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 09:14:17 +01:00
585 lines
18 KiB
Text
585 lines
18 KiB
Text
drop table if exists t1,t2,t3;
|
|
SET @saved_frequency = @@GLOBAL.innodb_purge_rseg_truncate_frequency;
|
|
SET GLOBAL innodb_purge_rseg_truncate_frequency = 1;
|
|
CREATE TABLE t2 (a int);
|
|
INSERT INTO t2 VALUES(1),(2),(3);
|
|
#
|
|
# Check first syntax and wrong usage
|
|
#
|
|
CREATE OR REPLACE TABLE IF NOT EXISTS t1 (a int);
|
|
ERROR HY000: Incorrect usage of OR REPLACE and IF NOT EXISTS
|
|
create or replace table mysql.general_log (a int);
|
|
ERROR HY000: You cannot 'CREATE OR REPLACE' a log table if logging is enabled
|
|
create or replace table mysql.slow_log (a int);
|
|
ERROR HY000: You cannot 'CREATE OR REPLACE' a log table if logging is enabled
|
|
#
|
|
# Usage when table doesn't exist
|
|
#
|
|
CREATE OR REPLACE TABLE t1 (a int);
|
|
CREATE TABLE t1 (a int);
|
|
ERROR 42S01: Table 't1' already exists
|
|
DROP TABLE t1;
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (a int);
|
|
CREATE TEMPORARY TABLE t1 (a int, b int, c int);
|
|
ERROR 42S01: Table 't1' already exists
|
|
DROP TEMPORARY TABLE t1;
|
|
#
|
|
# Testing with temporary tables
|
|
#
|
|
CREATE OR REPLACE TABLE t1 (a int);
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (a int);
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (a int, b int);
|
|
SHOW CREATE TABLE t1;
|
|
Table Create Table
|
|
t1 CREATE TEMPORARY TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
DROP TEMPORARY TABLE t1;
|
|
SHOW CREATE TABLE t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
DROP TABLE t1;
|
|
create temporary table t1 (i int) engine=InnoDB;
|
|
create or replace temporary table t1 (a int, b int) engine=InnoDB;
|
|
create or replace temporary table t1 (j int);
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TEMPORARY TABLE `t1` (
|
|
`j` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
drop table t1;
|
|
CREATE OR REPLACE TABLE t1 (a int);
|
|
LOCK TABLES t1 write;
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (a int);
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (a int, b int);
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (a int, b int) engine= innodb;
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (a int) engine= innodb;
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (a int, b int) engine=myisam;
|
|
SHOW CREATE TABLE t1;
|
|
Table Create Table
|
|
t1 CREATE TEMPORARY TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
DROP TEMPORARY TABLE t1;
|
|
SHOW CREATE TABLE t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
CREATE OR REPLACE TABLE t2 (a int);
|
|
ERROR HY000: Table 't2' was not locked with LOCK TABLES
|
|
DROP TABLE t1;
|
|
UNLOCK TABLES;
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (a int) SELECT * from t2;
|
|
SELECT * FROM t1;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
CREATE OR REPLACE TEMPORARY TABLE t1 (b int) SELECT * from t2;
|
|
SELECT * FROM t1;
|
|
b a
|
|
NULL 1
|
|
NULL 2
|
|
NULL 3
|
|
SHOW CREATE TABLE t1;
|
|
Table Create Table
|
|
t1 CREATE TEMPORARY TABLE `t1` (
|
|
`b` int(11) DEFAULT NULL,
|
|
`a` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
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;
|
|
Warnings:
|
|
Note 1050 Table 't1' already exists
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1 (a int);
|
|
CREATE OR REPLACE TABLE t1 AS SELECT 1;
|
|
SHOW CREATE TABLE t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`1` int(1) NOT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
DROP TABLE t1;
|
|
create table t1 (a int);
|
|
create or replace table t1 as select * from t1;
|
|
ERROR HY000: Table 't1' is specified twice, both as a target for 'CREATE' and as a separate source for data
|
|
create or replace table t1 as select a from (select a from t1) as t3;
|
|
ERROR HY000: Table 't1' is specified twice, both as a target for 'CREATE' and as a separate source for data
|
|
create or replace table t1 as select a from t2 where t2.a in (select a from t1);
|
|
ERROR HY000: Table 't1' is specified twice, both as a target for 'CREATE' and as a separate source for data
|
|
drop table t1;
|
|
#
|
|
# Testing with normal tables
|
|
#
|
|
CREATE OR REPLACE TABLE t1 (a int);
|
|
CREATE OR REPLACE TABLE t1 (a int, b int);
|
|
SHOW CREATE TABLE t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL,
|
|
`b` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1 (a int) SELECT * from t2;
|
|
SELECT * FROM t1;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
TRUNCATE TABLE t1;
|
|
CREATE TABLE IF NOT EXISTS t1 (a int) SELECT * from t2;
|
|
Warnings:
|
|
Note 1050 Table 't1' already exists
|
|
SELECT * FROM t1;
|
|
a
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1 (i int);
|
|
CREATE OR REPLACE TABLE t1 AS SELECT 1;
|
|
SHOW CREATE TABLE t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`1` int(1) NOT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
DROP TABLE t1;
|
|
CREATE OR REPLACE TABLE t1 (a int);
|
|
LOCK TABLES t1 write,t2 write;
|
|
CREATE OR REPLACE TABLE t1 (a int, b int);
|
|
SELECT * FROM t1;
|
|
a b
|
|
INSERT INTO t1 values(1,1);
|
|
CREATE OR REPLACE TABLE t1 (a int, b int, c int);
|
|
INSERT INTO t1 values(1,1,1);
|
|
CREATE OR REPLACE TABLE t3 (a int);
|
|
ERROR HY000: Table 't3' was not locked with LOCK TABLES
|
|
UNLOCK TABLES;
|
|
DROP TABLE t1;
|
|
CREATE OR REPLACE TABLE t1 (a int);
|
|
LOCK TABLES t1 write,t2 write;
|
|
CREATE OR REPLACE TABLE t1 (a int, b int) select a,1 from t2;
|
|
SELECT * FROM t2;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
SELECT * FROM t1;
|
|
b a 1
|
|
NULL 1 1
|
|
NULL 2 1
|
|
NULL 3 1
|
|
SELECT * FROM t1;
|
|
b a 1
|
|
NULL 1 1
|
|
NULL 2 1
|
|
NULL 3 1
|
|
INSERT INTO t1 values(1,1,1);
|
|
CREATE OR REPLACE TABLE t1 (a int, b int, c int, d int);
|
|
INSERT INTO t1 values(1,1,1,1);
|
|
CREATE OR REPLACE TABLE t3 (a int);
|
|
ERROR HY000: Table 't3' was not locked with LOCK TABLES
|
|
UNLOCK TABLES;
|
|
DROP TABLE t1;
|
|
CREATE OR REPLACE TABLE t1 (a int);
|
|
LOCK TABLES t1 write,t2 write, t1 as t1_read read;
|
|
CREATE OR REPLACE TABLE t1 (a int, b int) select a,1 from t2;
|
|
SELECT * FROM t1;
|
|
b a 1
|
|
NULL 1 1
|
|
NULL 2 1
|
|
NULL 3 1
|
|
SELECT * FROM t2;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
SELECT * FROM t1 as t1_read;
|
|
ERROR HY000: Table 't1_read' was not locked with LOCK TABLES
|
|
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;
|
|
1
|
|
1
|
|
SELECT * from t2;
|
|
ERROR HY000: Table 't2' was not locked with LOCK TABLES
|
|
DROP TABLE t1;
|
|
#
|
|
# Test also with InnoDB (transactional engine)
|
|
#
|
|
create table t1 (i int) engine=innodb;
|
|
lock table t1 write;
|
|
create or replace table t1 (j int);
|
|
unlock tables;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`j` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
drop table t1;
|
|
create table t1 (i int) engine=InnoDB;
|
|
lock table t1 write, t2 write;
|
|
create or replace table t1 (j int) engine=innodb;
|
|
unlock tables;
|
|
drop table t1;
|
|
create table t1 (i int) engine=InnoDB;
|
|
create table t3 (i int) engine=InnoDB;
|
|
insert into t3 values(1),(2),(3);
|
|
create table t4 (i int) engine=InnoDB;
|
|
insert into t4 values(1);
|
|
lock table t1 write, t2 write, t3 write, t4 write;
|
|
create or replace table t1 (a int, i int) engine=innodb select t2.a,t3.i from t2,t3;
|
|
select * from t4;
|
|
i
|
|
1
|
|
unlock tables;
|
|
select * from t1 order by a,i;
|
|
a i
|
|
1 1
|
|
1 2
|
|
1 3
|
|
2 1
|
|
2 2
|
|
2 3
|
|
3 1
|
|
3 2
|
|
3 3
|
|
drop table t1,t3,t4;
|
|
#
|
|
# Test the meta data locks are freed properly
|
|
#
|
|
create database mysqltest2;
|
|
drop table if exists test.t1,mysqltest2.t2;
|
|
Warnings:
|
|
Note 1051 Unknown table 'test.t1,mysqltest2.t2'
|
|
create table test.t1 (i int) engine=myisam;
|
|
create table mysqltest2.t2 like test.t1;
|
|
lock table test.t1 write, mysqltest2.t2 write;
|
|
InnoDB 0 transactions not purged
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_BACKUP_DML NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock mysqltest2
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock mysqltest2 t2
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock test t1
|
|
create or replace table test.t1;
|
|
ERROR 42000: A table must have at least 1 column
|
|
show tables;
|
|
Tables_in_test
|
|
t2
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_BACKUP_DML NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock mysqltest2
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock mysqltest2 t2
|
|
create or replace table mysqltest2.t2;
|
|
ERROR 42000: A table must have at least 1 column
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
create table t1 (i int);
|
|
drop table t1;
|
|
create table test.t1 (i int);
|
|
create table mysqltest2.t2 like test.t1;
|
|
lock table test.t1 write, mysqltest2.t2 write;
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_BACKUP_DML NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock mysqltest2
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock mysqltest2 t2
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock test t1
|
|
create or replace table test.t1 (a int) select 1 as 'a', 2 as 'a';
|
|
ERROR 42S21: Duplicate column name 'a'
|
|
show tables;
|
|
Tables_in_test
|
|
t2
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_BACKUP_DML NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock mysqltest2
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock mysqltest2 t2
|
|
create or replace table mysqltest2.t2 (a int) select 1 as 'a', 2 as 'a';
|
|
ERROR 42S21: Duplicate column name 'a'
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
create table t1 (i int);
|
|
drop table t1;
|
|
create table test.t1 (i int) engine=innodb;
|
|
create table mysqltest2.t2 like test.t1;
|
|
lock table test.t1 write, mysqltest2.t2 write;
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock mysqltest2
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock mysqltest2 t2
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock test t1
|
|
unlock tables;
|
|
drop table test.t1,mysqltest2.t2;
|
|
create table test.t1 (i int) engine=aria transactional=1 checksum=1;
|
|
create table mysqltest2.t2 like test.t1;
|
|
lock table test.t1 write, mysqltest2.t2 write;
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock mysqltest2
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock mysqltest2 t2
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock test t1
|
|
unlock tables;
|
|
drop table t1;
|
|
create table test.t1 (i int);
|
|
drop database mysqltest2;
|
|
drop table test.t1;
|
|
#
|
|
# MDEV-23391 Server crash in close_thread_table or assertion, upon CREATE OR REPLACE TABLE under lock
|
|
#
|
|
create table t1 (i int);
|
|
lock table t1 write;
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_BACKUP_DML NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock test t1
|
|
create or replace table t1 (a char(1)) engine=Innodb select 'foo' as a;
|
|
ERROR 22001: Data too long for column 'a' at row 1
|
|
show tables;
|
|
Tables_in_test
|
|
t2
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
create table t1 (i int);
|
|
drop table t1;
|
|
#
|
|
# Testing CREATE .. LIKE
|
|
#
|
|
create or replace table t1 like t2;
|
|
create or replace table t1 like t2;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
drop table t1;
|
|
create table t1 (b int);
|
|
lock tables t1 write, t2 read;
|
|
create or replace table t1 like t2;
|
|
SELECT * FROM t1;
|
|
a
|
|
INSERT INTO t1 values(1);
|
|
CREATE OR REPLACE TABLE t1 like t2;
|
|
INSERT INTO t1 values(2);
|
|
unlock tables;
|
|
show create table t1;
|
|
Table Create Table
|
|
t1 CREATE TABLE `t1` (
|
|
`a` int(11) DEFAULT NULL
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
drop table t1;
|
|
create or replace table t1 like t2;
|
|
create or replace table t1 like t1;
|
|
ERROR 42000: Not unique table/alias: 't1'
|
|
drop table t1;
|
|
CREATE TEMPORARY TABLE t1 like t2;
|
|
CREATE OR REPLACE TABLE t1 like t1;
|
|
ERROR 42000: Not unique table/alias: 't1'
|
|
CREATE OR REPLACE TABLE t1 like t1;
|
|
ERROR 42000: Not unique table/alias: 't1'
|
|
drop table t1;
|
|
CREATE TEMPORARY TABLE t1 like t2;
|
|
CREATE OR REPLACE TEMPORARY TABLE t3 like t1;
|
|
CREATE OR REPLACE TEMPORARY TABLE t3 like t3;
|
|
ERROR 42000: Not unique table/alias: 't3'
|
|
drop table t1,t3;
|
|
#
|
|
# Test with prepared statements
|
|
#
|
|
prepare stmt1 from 'create or replace table t1 select * from t2';
|
|
execute stmt1;
|
|
select * from t1;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
execute stmt1;
|
|
select * from t1;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
drop table t1;
|
|
execute stmt1;
|
|
select * from t1;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
deallocate prepare stmt1;
|
|
drop table t1;
|
|
#
|
|
# Test with views
|
|
#
|
|
create view t1 as select 1;
|
|
create table if not exists t1 (a int);
|
|
Warnings:
|
|
Note 1050 Table 't1' already exists
|
|
create or replace table t1 (a int);
|
|
ERROR 42S02: 'test.t1' is a view
|
|
drop table t1;
|
|
ERROR 42S02: 'test.t1' is a view
|
|
drop view t1;
|
|
#
|
|
# MDEV-5602 CREATE OR REPLACE obtains stricter locks than the
|
|
# connection had before
|
|
#
|
|
create table t1 (a int);
|
|
lock table t1 write, t2 read;
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_BACKUP_DML NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock test t1
|
|
# MDL_SHARED_READ NULL Table metadata lock test t2
|
|
create or replace table t1 (i int);
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_BACKUP_DML NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock test t1
|
|
# MDL_SHARED_READ NULL Table metadata lock test t2
|
|
create or replace table t1 like t2;
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_BACKUP_DML NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock test t1
|
|
# MDL_SHARED_READ NULL Table metadata lock test t2
|
|
create or replace table t1 select 1 as f1;
|
|
select * from information_schema.metadata_lock_info;
|
|
THREAD_ID LOCK_MODE LOCK_DURATION LOCK_TYPE TABLE_SCHEMA TABLE_NAME
|
|
# MDL_BACKUP_DDL NULL Backup lock
|
|
# MDL_BACKUP_DML NULL Backup lock
|
|
# MDL_INTENTION_EXCLUSIVE NULL Schema metadata lock test
|
|
# MDL_SHARED_NO_READ_WRITE NULL Table metadata lock test t1
|
|
# MDL_SHARED_READ NULL Table metadata lock test t2
|
|
drop table t1;
|
|
unlock tables;
|
|
#
|
|
# MDEV-6560
|
|
# Assertion `! is_set() ' failed in Diagnostics_area::set_ok_status
|
|
#
|
|
CREATE TABLE t1 (col_int_nokey INT) ENGINE=InnoDB;
|
|
CREATE OR REPLACE TEMPORARY TABLE tmp LIKE t1;
|
|
LOCK TABLE t1 WRITE;
|
|
connect con1,localhost,root,,test;
|
|
CREATE OR REPLACE TABLE t1 LIKE tmp;
|
|
connection default;
|
|
KILL QUERY con_id;
|
|
connection con1;
|
|
ERROR 70100: Query execution was interrupted
|
|
CREATE OR REPLACE TABLE t1 (a int);
|
|
connection default;
|
|
KILL QUERY con_id;
|
|
connection con1;
|
|
ERROR 70100: Query execution was interrupted
|
|
disconnect con1;
|
|
connection default;
|
|
drop table t1;
|
|
DROP TABLE t2;
|
|
#
|
|
# MDEV-10824 - Crash in CREATE OR REPLACE TABLE t1 AS SELECT spfunc()
|
|
#
|
|
CREATE TABLE t1(a INT);
|
|
CREATE FUNCTION f1() RETURNS VARCHAR(16383) RETURN 'test';
|
|
CREATE OR REPLACE TABLE t1 AS SELECT f1();
|
|
LOCK TABLE t1 WRITE;
|
|
CREATE OR REPLACE TABLE t1 AS SELECT f1();
|
|
UNLOCK TABLES;
|
|
DROP FUNCTION f1;
|
|
DROP TABLE t1;
|
|
#
|
|
# MDEV-11129
|
|
# CREATE OR REPLACE TABLE t1 AS SELECT spfunc() crashes if spfunc()
|
|
# references t1
|
|
#
|
|
CREATE OR REPLACE TABLE t1(a INT);
|
|
CREATE FUNCTION f1() RETURNS VARCHAR(16383)
|
|
BEGIN
|
|
INSERT INTO t1 VALUES(1);
|
|
RETURN 'test';
|
|
END;
|
|
$$
|
|
CREATE OR REPLACE TABLE t1 AS SELECT f1();
|
|
ERROR HY000: Table 't1' is specified twice, both as a target for 'CREATE' and as a separate source for data
|
|
LOCK TABLE t1 WRITE;
|
|
CREATE OR REPLACE TABLE t1 AS SELECT f1();
|
|
ERROR HY000: Table 't1' was not locked with LOCK TABLES
|
|
UNLOCK TABLES;
|
|
DROP FUNCTION f1;
|
|
DROP TABLE t1;
|
|
#
|
|
# MDEV-14410 - Assertion `table->pos_in_locked_tables == __null ||
|
|
# table->pos_in_locked_tables->table == table' failed in
|
|
# mark_used_tables_as_free_for_reuse
|
|
#
|
|
CREATE TABLE t1 (a INT);
|
|
CREATE TABLE t2 (b INT);
|
|
CREATE TABLE t3 (c INT);
|
|
CREATE TRIGGER tr1 BEFORE INSERT ON t3 FOR EACH ROW INSERT INTO t1 VALUES ();
|
|
CREATE TRIGGER tr2 BEFORE INSERT ON t2 FOR EACH ROW INSERT INTO t3 SELECT * FROM t1;
|
|
LOCK TABLE t1 WRITE, t2 WRITE;
|
|
CREATE OR REPLACE TABLE t1 (i INT);
|
|
UNLOCK TABLES;
|
|
INSERT INTO t2 VALUES (1);
|
|
DROP TABLE t1, t2, t3;
|
|
#
|
|
# MDEV-11071 - Assertion `thd->transaction.stmt.is_empty()' failed in
|
|
# Locked_tables_list::unlock_locked_tables
|
|
#
|
|
CREATE TEMPORARY TABLE t1(a INT) ENGINE=InnoDB;
|
|
CREATE TEMPORARY TABLE t2(a INT);
|
|
CREATE TABLE t3(a INT);
|
|
LOCK TABLE t2 WRITE;
|
|
SELECT * FROM t2;
|
|
a
|
|
CREATE OR REPLACE TEMPORARY TABLE t1(c INT DEFAULT '');
|
|
ERROR 42000: Invalid default value for 'c'
|
|
SELECT * FROM t3;
|
|
ERROR HY000: Table 't3' was not locked with LOCK TABLES
|
|
CREATE OR REPLACE TEMPORARY TABLE t2(c INT DEFAULT '');
|
|
ERROR 42000: Invalid default value for 'c'
|
|
SELECT * FROM t3;
|
|
ERROR HY000: Table 't3' was not locked with LOCK TABLES
|
|
UNLOCK TABLES;
|
|
DROP TABLE t3;
|
|
#
|
|
# MDEV-29697 Assertion failure in Diagnostics_area::set_ok_status
|
|
# upon CREATE OR REPLACE causing ER_UPDATE_TABLE_USED
|
|
#
|
|
CREATE TABLE t (a INT) ENGINE=MyISAM;
|
|
CREATE TABLE tm (a INT) ENGINE=MERGE UNION(t);
|
|
CREATE OR REPLACE TABLE t LIKE tm;
|
|
ERROR HY000: Table 'tm' is specified twice, both as a target for 'CREATE' and as a separate source for data
|
|
DROP TABLE IF EXISTS tm, t;
|
|
SET GLOBAL innodb_purge_rseg_truncate_frequency = @saved_frequency;
|
|
#
|
|
# End of 10.3 tests
|
|
#
|
|
# End of 10.4 tests
|