1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
# test simple MVCC, that a transaction does not read something committed after it
--source include/have_tokudb.inc
SET DEFAULT_STORAGE_ENGINE = 'tokudb';
set session transaction isolation level repeatable read;
--echo # Establish connection conn1 (user = root)
connect (conn1,localhost,root,,);
--disable_warnings
DROP TABLE IF EXISTS foo;
--enable_warnings
connection conn1;
set session transaction isolation level repeatable read;
create table foo (a int) engine=TokuDB;
insert into foo values (1);
begin;
select * from foo;
connection default;
alter table foo add column b int;
alter table foo change b b bigint;
truncate table foo;
rename table foo to bar;
drop table bar;
connection conn1;
--error ER_NO_SUCH_TABLE
select * From foo;
connection conn1;
set session transaction isolation level serializable;
create table foo (a int) engine=TokuDB;
insert into foo values (1);
begin;
insert into foo values(2);
connection default;
--error ER_LOCK_WAIT_TIMEOUT
alter table foo add column b int;
--error ER_LOCK_WAIT_TIMEOUT
alter table foo change a a bigint;
--error ER_LOCK_WAIT_TIMEOUT
truncate table foo;
--error ER_ERROR_ON_RENAME
rename table foo to bar;
--error ER_BAD_TABLE_ERROR
drop table foo;
connection conn1;
select * From foo;
commit;
connection default;
disconnect conn1;
drop table foo;
|