mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 20:36:16 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			269 lines
		
	
	
	
		
			5.9 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			269 lines
		
	
	
	
		
			5.9 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
DROP TABLE IF EXISTS table_11733 ;
 | 
						|
create user test@localhost;
 | 
						|
grant CREATE, SELECT, DROP, INSERT on *.* to test@localhost;
 | 
						|
connect  con1,localhost,test,,test;
 | 
						|
connection default;
 | 
						|
set global read_only=0;
 | 
						|
create table table_11733 (a int) engine=InnoDb;
 | 
						|
connection con1;
 | 
						|
BEGIN;
 | 
						|
insert into table_11733 values(11733);
 | 
						|
connection default;
 | 
						|
set global read_only=1;
 | 
						|
connection con1;
 | 
						|
select @@global.read_only;
 | 
						|
@@global.read_only
 | 
						|
1
 | 
						|
select * from table_11733 ;
 | 
						|
a
 | 
						|
11733
 | 
						|
COMMIT;
 | 
						|
ERROR HY000: The MariaDB server is running with the --read-only option so it cannot execute this statement
 | 
						|
connection default;
 | 
						|
set global read_only=0;
 | 
						|
drop table table_11733 ;
 | 
						|
drop user test@localhost;
 | 
						|
disconnect con1;
 | 
						|
create user test@localhost;
 | 
						|
GRANT CREATE, SELECT, DROP, LOCK TABLES ON *.* TO test@localhost;
 | 
						|
connect con1, localhost, test, , test;
 | 
						|
connection default;
 | 
						|
CREATE TABLE t1(a INT) ENGINE=INNODB;
 | 
						|
INSERT INTO t1 VALUES (0), (1);
 | 
						|
SET GLOBAL read_only=1;
 | 
						|
connection con1;
 | 
						|
SELECT * FROM t1;
 | 
						|
a
 | 
						|
0
 | 
						|
1
 | 
						|
BEGIN;
 | 
						|
SELECT * FROM t1;
 | 
						|
a
 | 
						|
0
 | 
						|
1
 | 
						|
COMMIT;
 | 
						|
connection default;
 | 
						|
SET GLOBAL read_only=0;
 | 
						|
FLUSH TABLES WITH READ LOCK;
 | 
						|
connection con1;
 | 
						|
SELECT * FROM t1;
 | 
						|
a
 | 
						|
0
 | 
						|
1
 | 
						|
BEGIN;
 | 
						|
SELECT * FROM t1;
 | 
						|
a
 | 
						|
0
 | 
						|
1
 | 
						|
COMMIT;
 | 
						|
connection default;
 | 
						|
UNLOCK TABLES;
 | 
						|
connection con1;
 | 
						|
lock table t1 read;
 | 
						|
connection default;
 | 
						|
set global read_only=1;
 | 
						|
connection con1;
 | 
						|
unlock tables;
 | 
						|
connection default;
 | 
						|
SET GLOBAL read_only=0;
 | 
						|
UNLOCK TABLES;
 | 
						|
DROP TABLE t1;
 | 
						|
DROP USER test@localhost;
 | 
						|
disconnect con1;
 | 
						|
# End of 5.1 tests
 | 
						|
#
 | 
						|
# Bug#33669: Transactional temporary tables do not work under --read-only
 | 
						|
#
 | 
						|
DROP DATABASE IF EXISTS db1;
 | 
						|
# Setup user and tables
 | 
						|
CREATE USER bug33669@localhost;
 | 
						|
CREATE DATABASE db1;
 | 
						|
CREATE TABLE db1.t1 (a INT) ENGINE=INNODB;
 | 
						|
CREATE TABLE db1.t2 (a INT) ENGINE=INNODB;
 | 
						|
INSERT INTO db1.t1 VALUES (1);
 | 
						|
INSERT INTO db1.t2 VALUES (2);
 | 
						|
GRANT CREATE TEMPORARY TABLES, DROP, INSERT, DELETE, UPDATE,
 | 
						|
SELECT, LOCK TABLES ON db1.* TO bug33669@localhost;
 | 
						|
SET GLOBAL READ_ONLY = ON;
 | 
						|
connect con1,localhost,bug33669,,db1;
 | 
						|
 | 
						|
# Create, insert and drop temporary table:
 | 
						|
 | 
						|
CREATE TEMPORARY TABLE temp (a INT) ENGINE=INNODB;
 | 
						|
INSERT INTO temp VALUES (1);
 | 
						|
DROP TABLE temp;
 | 
						|
 | 
						|
# Lock base tables and use temporary table:
 | 
						|
 | 
						|
CREATE TEMPORARY TABLE temp (a INT) ENGINE=INNODB;
 | 
						|
LOCK TABLES t1 READ, t2 READ;
 | 
						|
SELECT * FROM t1;
 | 
						|
a
 | 
						|
1
 | 
						|
INSERT INTO temp values (1);
 | 
						|
SELECT * FROM t2;
 | 
						|
a
 | 
						|
2
 | 
						|
UNLOCK TABLES;
 | 
						|
DROP TABLE temp;
 | 
						|
 | 
						|
# Transaction
 | 
						|
 | 
						|
BEGIN;
 | 
						|
SELECT * FROM t1;
 | 
						|
a
 | 
						|
1
 | 
						|
CREATE TEMPORARY TABLE temp (a INT) ENGINE=INNODB;
 | 
						|
INSERT INTO t1 VALUES (1);
 | 
						|
ERROR HY000: The MariaDB server is running with the --read-only option so it cannot execute this statement
 | 
						|
INSERT INTO temp VALUES (1);
 | 
						|
SELECT * FROM t2;
 | 
						|
a
 | 
						|
2
 | 
						|
ROLLBACK;
 | 
						|
SELECT * FROM temp;
 | 
						|
a
 | 
						|
DROP TABLE temp;
 | 
						|
 | 
						|
# Lock base table as READ and temporary table as WRITE:
 | 
						|
 | 
						|
CREATE TEMPORARY TABLE temp (a INT) ENGINE=INNODB;
 | 
						|
LOCK TABLES t1 READ, temp WRITE;
 | 
						|
SELECT * FROM t1;
 | 
						|
a
 | 
						|
1
 | 
						|
SELECT * FROM temp;
 | 
						|
a
 | 
						|
INSERT INTO t1 VALUES (1);
 | 
						|
ERROR HY000: The MariaDB server is running with the --read-only option so it cannot execute this statement
 | 
						|
INSERT INTO temp VALUES (1);
 | 
						|
DROP TABLE temp;
 | 
						|
UNLOCK TABLES;
 | 
						|
 | 
						|
# Lock temporary table that shadows a base table:
 | 
						|
 | 
						|
CREATE TEMPORARY TABLE t1 (a INT) ENGINE=INNODB;
 | 
						|
LOCK TABLES t1 WRITE;
 | 
						|
DROP TABLE t1;
 | 
						|
SELECT * FROM t1;
 | 
						|
ERROR HY000: Table 't1' was not locked with LOCK TABLES
 | 
						|
 | 
						|
# INSERT SELECT from base table into temporary table:
 | 
						|
 | 
						|
CREATE TEMPORARY TABLE temp1 (a INT) ENGINE=INNODB;
 | 
						|
CREATE TEMPORARY TABLE temp2 LIKE temp1;
 | 
						|
BEGIN;
 | 
						|
INSERT INTO temp1 VALUES (10);
 | 
						|
INSERT INTO temp2 VALUES (10);
 | 
						|
INSERT INTO temp1 SELECT * FROM t1;
 | 
						|
INSERT INTO temp2 SELECT * FROM t2;
 | 
						|
SELECT * FROM temp1 ORDER BY a;
 | 
						|
a
 | 
						|
1
 | 
						|
10
 | 
						|
SELECT * FROM temp2 ORDER BY a;
 | 
						|
a
 | 
						|
2
 | 
						|
10
 | 
						|
ROLLBACK;
 | 
						|
SELECT * FROM temp1,temp2;
 | 
						|
a	a
 | 
						|
LOCK TABLES t1 READ, t2 READ;
 | 
						|
INSERT INTO temp1 VALUES (10);
 | 
						|
INSERT INTO temp2 VALUES (10);
 | 
						|
INSERT INTO temp1 SELECT * FROM t1;
 | 
						|
INSERT INTO temp2 SELECT * FROM t2;
 | 
						|
SELECT * FROM temp1 ORDER BY a;
 | 
						|
a
 | 
						|
1
 | 
						|
10
 | 
						|
SELECT * FROM temp2 ORDER BY a;
 | 
						|
a
 | 
						|
2
 | 
						|
10
 | 
						|
UNLOCK TABLES;
 | 
						|
DELETE temp1, temp2 FROM temp1, temp2;
 | 
						|
INSERT INTO temp1 VALUES (10);
 | 
						|
INSERT INTO temp2 VALUES (10);
 | 
						|
INSERT INTO temp1 SELECT * FROM t1;
 | 
						|
INSERT INTO temp2 SELECT * FROM t2;
 | 
						|
SELECT * FROM temp1 ORDER BY a;
 | 
						|
a
 | 
						|
1
 | 
						|
10
 | 
						|
SELECT * FROM temp2 ORDER BY a;
 | 
						|
a
 | 
						|
2
 | 
						|
10
 | 
						|
DROP TABLE temp1, temp2;
 | 
						|
 | 
						|
# INSERT and INSERT SELECT that uses subqueries:
 | 
						|
CREATE TEMPORARY TABLE temp1 (a INT) ENGINE=INNODB;
 | 
						|
CREATE TEMPORARY TABLE temp2 LIKE temp1;
 | 
						|
INSERT INTO temp1 (a) VALUES ((SELECT MAX(a) FROM t1));
 | 
						|
LOCK TABLES t2 READ;
 | 
						|
INSERT INTO temp2 (a) VALUES ((SELECT MAX(a) FROM t2));
 | 
						|
UNLOCK TABLES;
 | 
						|
LOCK TABLES t1 READ, t2 READ;
 | 
						|
INSERT INTO temp1 SELECT * FROM t1 WHERE a < (SELECT MAX(a) FROM t2);
 | 
						|
INSERT INTO temp2 SELECT * FROM t2 WHERE a > (SELECT MAX(a) FROM t1);
 | 
						|
UNLOCK TABLES;
 | 
						|
INSERT INTO temp1 SELECT * FROM t1 WHERE a < (SELECT MAX(a) FROM t2);
 | 
						|
INSERT INTO temp2 SELECT * FROM t2 WHERE a > (SELECT MAX(a) FROM t1);
 | 
						|
SELECT * FROM temp1 ORDER BY a;
 | 
						|
a
 | 
						|
1
 | 
						|
1
 | 
						|
1
 | 
						|
SELECT * FROM temp2 ORDER BY a;
 | 
						|
a
 | 
						|
2
 | 
						|
2
 | 
						|
2
 | 
						|
DROP TABLE temp1, temp2;
 | 
						|
 | 
						|
# Multiple table update:
 | 
						|
 | 
						|
CREATE TEMPORARY TABLE temp1 (a INT) ENGINE=INNODB;
 | 
						|
CREATE TEMPORARY TABLE temp2 LIKE temp1;
 | 
						|
INSERT INTO temp1 VALUES (1),(2);
 | 
						|
INSERT INTO temp2 VALUES (3),(4);
 | 
						|
UPDATE temp1,temp2 SET temp1.a = 5, temp2.a = 10;
 | 
						|
SELECT * FROM temp1, temp2;
 | 
						|
a	a
 | 
						|
5	10
 | 
						|
5	10
 | 
						|
5	10
 | 
						|
5	10
 | 
						|
DROP TABLE temp1, temp2;
 | 
						|
 | 
						|
# Disconnect and cleanup
 | 
						|
 | 
						|
disconnect con1;
 | 
						|
connection default;
 | 
						|
SET GLOBAL READ_ONLY = OFF;
 | 
						|
DROP USER bug33669@localhost;
 | 
						|
DROP DATABASE db1;
 | 
						|
# End of 5.5 tests
 | 
						|
#
 | 
						|
# MDEV-33889 Read only server throws error when running a create temporary table as select statement
 | 
						|
#
 | 
						|
create table t1(a int) engine=innodb;
 | 
						|
create user u1@localhost;
 | 
						|
grant insert, select, update, delete, create temporary tables on test.* to u1@localhost;
 | 
						|
insert into t1 values (1);
 | 
						|
set global read_only=1;
 | 
						|
connect u1,localhost,u1;
 | 
						|
set default_tmp_storage_engine=innodb;
 | 
						|
create temporary table tt1 (a int);
 | 
						|
create temporary table tt2 like t1;
 | 
						|
create temporary table tt3 as select * from t1;
 | 
						|
select * from tt3;
 | 
						|
a
 | 
						|
1
 | 
						|
disconnect u1;
 | 
						|
connection default;
 | 
						|
drop table t1;
 | 
						|
drop user u1@localhost;
 | 
						|
set global read_only=0;
 | 
						|
# End of 10.5 tests
 |