mariadb/mysql-test/t/implicit_commit.test

1163 lines
20 KiB
Text
Raw Normal View History

Backport of: ------------------------------------------------------------ revno: 2630.13.16 committer: Davi Arnaut <Davi.Arnaut@Sun.COM> branch nick: WL#4284 timestamp: Sat 2008-07-26 13:38:20 -0300 message: WL#4284: Transactional DDL locking SQL statements' effect on transactions. Currently the MySQL server and its storage engines are not capable of rolling back operations that define or modify data structures (also known as DDL statements) or operations that alter any of the system tables (the mysql database). Allowing these group of statements to participate in transactions is unfeasible at this time (since rollback has no effect whatsoever on them) and goes against the design of our metadata locking subsystem. The solution is to issue implicit commits before and after those statements execution. This effectively confines each of those statements to its own special transaction and ensures that metadata locks taken during this special transaction are not leaked into posterior statements/transactions. mysql-test/include/commit.inc: Alter table rename was not committing the normal transaction at the end of its execution, and as a consequence, the commit was being issued in the next DDL command (rename table) that happened to end the active transaction. Other changes are to take into account the implicit commits issued before and after the DDL command execution. mysql-test/include/implicit_commit_helper.inc: Add auxiliary test that shows if a statement issued a implicit commit. mysql-test/r/commit_1innodb.result: Update test case result. mysql-test/r/implicit_commit.result: Test implicit commit behavior of some SQL commands. mysql-test/t/implicit_commit.test: Test implicit commit behavior of some SQL commands. sql/events.cc: Transaction is now ended before the command execution. sql/mysql_priv.h: Add flags array for server commands and remove historical left over. sql/sql_class.h: Add flags to control when to issue implicit commits before and after a command execution. sql/sql_delete.cc: A implicit commit is issued at the end of truncate statements. sql/sql_parse.cc: Mark commands that need implicit commits before and after their executions. The implicit commits of the statement and the normal transaction are now issued regardless of the user access privileges. sql/sql_table.cc: A implicit commit is now issued before admin commands. tests/mysql_client_test.c: Test that COM_REFRESH issues a implicit commit.
2009-12-03 16:47:20 +01:00
source include/have_innodb.inc;
source include/have_log_bin.inc;
SET GLOBAL EVENT_SCHEDULER = OFF;
SET BINLOG_FORMAT = STATEMENT;
LET $OLD_DB= `SELECT DATABASE()`;
CREATE DATABASE db1;
USE db1;
CREATE TABLE t1 (a INT, KEY a(a)) ENGINE=INNODB;
INSERT INTO t1 VALUES (1),(2),(3),(4),(5);
CREATE TABLE t3 (a INT) ENGINE=MyISAM;
INSERT INTO t3 SELECT * FROM t1;
CREATE TABLE trans (a INT) ENGINE=INNODB;
DELIMITER |;
CREATE PROCEDURE test_if_commit()
BEGIN
ROLLBACK;
SELECT IF (COUNT(*) > 0, "YES", "NO") AS "IMPLICIT COMMIT" FROM trans;
DELETE FROM trans;
COMMIT;
END|
DELIMITER ;|
SET AUTOCOMMIT = FALSE;
--echo #
--echo # SQLCOM_SELECT
--echo #
let $statement=
select 1 as res from t1 where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CREATE_TABLE LIKE
--echo #
let $statement=
create table t2 like t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_CREATE
--echo #
let $statement=
show create table t2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DROP_TABLE
--echo #
let $statement=
drop table t2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CREATE_TABLE TEMPORARY
--echo #
let $statement=
create temporary table t2 as select * from t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DROP_TABLE TEMPORARY
--echo #
let $statement=
drop temporary table t2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CREATE_TABLE
--echo #
let $statement=
create table t2 as select * from t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_UPDATE
--echo #
let $statement=
update t2 set a=a+1 where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_INSERT
--echo #
let $statement=
insert into t2 set a=((1) in (select * from t1));
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_INSERT_SELECT
--echo #
let $statement=
insert into t2 select * from t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_REPLACE
--echo #
let $statement=
replace t2 set a=((1) in (select * from t1));
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_REPLACE_SELECT
--echo #
let $statement=
replace t2 select * from t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DELETE
--echo #
let $statement=
delete from t2 where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DELETE_MULTI
--echo #
let $statement=
delete t2, t3 from t2, t3 where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_UPDATE_MULTI
--echo #
select * from t2;
let $statement=
update t2, t3 set t3.a=t2.a, t2.a=null where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_LOAD
--echo #
create table t4 (a varchar(100));
let $statement=
load data infile '../../std_data/words.dat' into table t4;
source include/implicit_commit_helper.inc;
drop table t4;
--echo #
--echo # SQLCOM_SHOW_DATABASES
--echo #
let $statement=
show databases where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_TABLES
--echo #
let $statement=
show tables where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_FIELDS
--echo #
let $statement=
show fields from t1 where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_KEYS
--echo #
let $statement=
show keys from t1 where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_VARIABLES
--echo #
let $statement=
show variables where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_STATUS
--echo #
let $statement=
show status where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_ENGINE_MUTEX
--echo #
let $statement=
show engine all mutex;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_PROCESSLIST
--echo #
let $statement=
show processlist;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_ENGINE_LOGS
--echo #
let $statement=
show engine all logs;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_ENGINE_STATUS
--echo #
let $statement=
show engine all status;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_CHARSETS
--echo #
let $statement=
show charset where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_COLLATIONS
--echo #
let $statement=
show collation where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_TABLE_STATUS
--echo #
let $statement=
show table status where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_TRIGGERS
--echo #
let $statement=
show triggers where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_OPEN_TABLES
--echo #
let $statement=
show open tables where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_STATUS_PROC
--echo #
let $statement=
show procedure status where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_STATUS_FUNC
--echo #
let $statement=
show function status where (1) in (select * from t1);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SET_OPTION
--echo #
let $statement=
set @a=((1) in (select * from t1));
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DO
--echo #
let $statement=
do ((1) in (select * from t1));
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CALL
--echo #
create procedure p1(a int) begin end;
let $statement=
call p1((1) in (select * from t1));
source include/implicit_commit_helper.inc;
drop procedure p1;
--echo #
--echo # SQLCOM_CREATE_VIEW
--echo #
let $statement=
create view v1 as select * from t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ALTER_VIEW
--echo #
let $statement=
alter view v1 as select 2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DROP_VIEW
--echo #
let $statement=
drop view v1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CREATE_INDEX
--echo #
let $statement=
create index idx1 on t1(a);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DROP_INDEX
--echo #
let $statement=
drop index idx1 on t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ALTER_TABLE
--echo #
let $statement=
alter table t1 add column b int;
source include/implicit_commit_helper.inc;
let $statement=
alter table t1 change b c int;
source include/implicit_commit_helper.inc;
let $statement=
alter table t1 drop column c;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ALTER_TABLE TEMPORARY
--echo #
create temporary table t4 (a int);
let $statement=
alter table t1 add column b int;
source include/implicit_commit_helper.inc;
let $statement=
alter table t1 change b c int;
source include/implicit_commit_helper.inc;
let $statement=
alter table t1 drop column c;
source include/implicit_commit_helper.inc;
drop table t4;
--echo #
--echo # SQLCOM_TRUNCATE
--echo #
insert into t2 select * from t1;
let $statement=
truncate table t2;
source include/implicit_commit_helper.inc;
insert into t2 select * from t1;
--echo #
--echo # SQLCOM_TRUNCATE TEMPORARY
--echo #
create temporary table t4 as select * from t1;
let $statement=
truncate table t4;
source include/implicit_commit_helper.inc;
drop temporary table t4;
--echo #
--echo # SQLCOM_SHOW_MASTER_STAT
--echo #
let $statement=
show master status;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_SLAVE_STAT
--echo #
let $statement=
show slave status;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_GRANT
--echo #
let $statement=
grant all on test.t1 to mysqltest_2@localhost with grant option;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_REVOKE
--echo #
let $statement=
revoke select on test.t1 from mysqltest_2@localhost;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_REVOKE_ALL
--echo #
let $statement=
revoke all on test.t1 from mysqltest_2@localhost;
source include/implicit_commit_helper.inc;
drop user mysqltest_2@localhost;
--echo #
--echo # SQLCOM_SHOW_GRANTS
--echo #
let $statement=
show grants;
source include/implicit_commit_helper.inc;
let $statement=
show grants for current_user();
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_LOCK_TABLES
--echo #
let $statement=
lock tables t1 write, trans write;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_UNLOCK_TABLES
--echo #
let $statement=
unlock tables;
source include/implicit_commit_helper.inc;
#
# Missing test for lock tables transactional.
#
--echo #
--echo # SQLCOM_CREATE_DB
--echo #
let $statement=
create database db2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CHANGE_DB
--echo #
create table db2.t1 (a int);
insert into db2.t1 values (1);
commit;
let $statement=
use db2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_CREATE_DB
--echo #
let $statement=
show create database db2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ALTER_DB
--echo #
#let $statement=
# alter database db2 character set koi8r;
#source include/implicit_commit_helper.inc;
#let $statement=
# alter database db2 collate cp1251_general_cs;
#source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ALTER_DB_UPGRADE
--echo #
#let $statement=
# alter database `#mysql50#db3` upgrade data directory name;
#source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DROP_DB
--echo #
use db1;
let $statement=
drop database db2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_REPAIR
--echo #
let $statement=
repair table t2;
source include/implicit_commit_helper.inc;
let $statement=
repair table t2 use_frm;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_OPTIMIZE
--echo #
let $statement=
optimize table t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CHECK
--echo #
let $statement=
check table t1;
source include/implicit_commit_helper.inc;
let $statement=
check table t1 extended;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ASSIGN_TO_KEYCACHE
--echo #
set global keycache.key_buffer_size=128*1024;
let $statement=
cache index t3 in keycache;
source include/implicit_commit_helper.inc;
set global keycache.key_buffer_size=0;
--echo #
--echo # SQLCOM_PRELOAD_KEYS
--echo #
let $statement=
load index into cache t3;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_FLUSH
--echo #
let $statement=
flush local privileges;
source include/implicit_commit_helper.inc;
let $statement=
flush privileges;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_KILL
--echo #
--echo #
--echo # SQLCOM_ANALYZE
--echo #
let $statement=
analyze table t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ROLLBACK
--echo #
let $statement=
rollback;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ROLLBACK_TO_SAVEPOINT
--echo #
--echo #
--echo # SQLCOM_COMMIT
--echo #
let $statement=
commit;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SAVEPOINT
--echo #
let $statement=
savepoint sp1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_RELEASE_SAVEPOINT
--echo #
--echo #
--echo # SQLCOM_SLAVE_START
--echo #
--echo #
--echo # SQLCOM_SLAVE_STOP
--echo #
--echo #
--echo # SQLCOM_BEGIN
--echo #
let $statement=
begin;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CHANGE_MASTER
--echo #
--echo #
--echo # SQLCOM_RENAME_TABLE
--echo #
let $statement=
rename table t3 to t4;
source include/implicit_commit_helper.inc;
let $statement=
rename table t4 to t3;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_RESET
--echo #
--echo #
--echo # SQLCOM_PURGE
--echo #
--echo #
--echo # SQLCOM_PURGE_BEFORE
--echo #
--echo #
--echo # SQLCOM_SHOW_BINLOGS
--echo #
--echo #
--echo # SQLCOM_HA_OPEN
--echo #
let $statement=
handler t1 open as ha1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_HA_READ
--echo #
let $statement=
handler ha1 read a first;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_HA_CLOSE
--echo #
let $statement=
handler ha1 close;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_SLAVE_HOSTS
--echo #
let $statement=
show slave hosts;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_BINLOG_EVENTS
--echo #
let $statement=
show binlog events;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_NEW_MASTER
--echo #
--echo #
--echo # SQLCOM_SHOW_WARNS
--echo #
let $statement=
show warnings;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_EMPTY_QUERY
--echo #
--echo #
--echo # SQLCOM_SHOW_ERRORS
--echo #
let $statement=
show errors;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_STORAGE_ENGINES
--echo #
let $statement=
show engines;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_PRIVILEGES
--echo #
let $statement=
show privileges;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_HELP
--echo #
let $statement=
help 'foo';
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CREATE_USER
--echo #
let $statement=
create user trxusr1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_RENAME_USER
--echo #
let $statement=
rename user 'trxusr1' to 'trxusr2';
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DROP_USER
--echo #
let $statement=
drop user trxusr2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CHECKSUM
--echo #
let $statement=
checksum table t1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CREATE_PROCEDURE
--echo #
let $statement=
create procedure p1(a int) begin end;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ALTER_PROCEDURE
--echo #
let $statement=
alter procedure p1 comment 'foobar';
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_CREATE_PROC
--echo #
let $statement=
show create procedure p1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_STATUS_PROC
--echo #
let $statement=
show procedure status;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_PROC_CODE
--echo #
#
# Available only on servers with debugging support.
#
--disable_abort_on_error
let $statement=
show procedure code p1;
source include/implicit_commit_helper.inc;
--enable_abort_on_error
--echo #
--echo # SQLCOM_DROP_PROCEDURE
--echo #
let $statement=
drop procedure p1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CREATE_FUNCTION
--echo #
--echo #
--echo # SQLCOM_DROP_FUNCTION
--echo #
--echo #
--echo # SQLCOM_CREATE_SPFUNCTION
--echo #
let $statement=
create function f1() returns int return 69;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ALTER_FUNCTION
--echo #
let $statement=
alter function f1 comment 'comment';
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_CREATE_FUNC
--echo #
let $statement=
show create function f1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_STATUS_FUNC
--echo #
let $statement=
show function status like '%f%';
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_FUNC_CODE
--echo #
#
# Available only on servers with debugging support.
#
--disable_abort_on_error
let $statement=
show function code f1;
source include/implicit_commit_helper.inc;
--enable_abort_on_error
--echo #
--echo # SQLCOM_PREPARE
--echo #
let $statement=
prepare stmt1 from "insert into t1 values (5)";
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_EXECUTE
--echo #
let $statement=
execute stmt1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DEALLOCATE_PREPARE
--echo #
let $statement=
deallocate prepare stmt1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CREATE_TRIGGER
--echo #
let $statement=
create trigger trg1 before insert on t1 for each row set @a:=1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_CREATE_TRIGGER
--echo #
let $statement=
show create trigger trg1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DROP_TRIGGER
--echo #
let $statement=
drop trigger trg1;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_XA_START
--echo #
--echo #
--echo # SQLCOM_XA_END
--echo #
--echo #
--echo # SQLCOM_XA_PREPARE
--echo #
--echo #
--echo # SQLCOM_XA_COMMIT
--echo #
--echo #
--echo # SQLCOM_XA_ROLLBACK
--echo #
--echo #
--echo # SQLCOM_XA_RECOVER
--echo #
--echo #
--echo # SQLCOM_ALTER_TABLESPACE
--echo #
--echo #
--echo # SQLCOM_INSTALL_PLUGIN
--echo #
--echo #
--echo # SQLCOM_SHOW_PLUGINS
--echo #
--echo #
--echo # SQLCOM_UNINSTALL_PLUGIN
--echo #
--echo #
--echo # SQLCOM_SHOW_AUTHORS
--echo #
let $statement=
show authors;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_BINLOG_BASE64_EVENT
--echo #
--echo #
--echo # SQLCOM_SHOW_CONTRIBUTORS
--echo #
let $statement=
show contributors;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_CREATE_SERVER
--echo #
--echo #
--echo # SQLCOM_ALTER_SERVER
--echo #
--echo #
--echo # SQLCOM_DROP_SERVER
--echo #
--echo #
--echo # SQLCOM_CREATE_EVENT
--echo #
let $statement=
create event ev1 on schedule every 1 second do insert into t1 values (6);
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_ALTER_EVENT
--echo #
let $statement=
alter event ev1 rename to ev2 disable;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_CREATE_EVENT
--echo #
let $statement=
show create event ev2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_EVENTS
--echo #
let $statement=
show events;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_DROP_EVENT
--echo #
let $statement=
drop event ev2;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_BACKUP
--echo #
#create database backup_db;
#
#let $statement=
# backup database db1 to 'backup_db1.ba';
#source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_ARCHIVE
--echo #
#
# --error ER_NOT_ALLOWED_COMMAND
#
#let $statement=
# show backup 'backup_db1.ba';
#source include/implicit_commit_helper.inc;
#
--echo #
--echo # SQLCOM_RESTORE
--echo #
#let $statement=
# restore from 'backup_db1.ba';
#source include/implicit_commit_helper.inc;
#--remove_file $MYSQLTEST_VARDIR/master-data/backup_db1.ba
#
#drop database backup_db;
--echo #
--echo # SQLCOM_BACKUP_TEST
--echo #
# BACKUP_TEST
--echo #
--echo # SQLCOM_SHOW_PROFILE
--echo #
let $statement=
show profile memory;
source include/implicit_commit_helper.inc;
--echo #
--echo # SQLCOM_SHOW_PROFILES
--echo #
let $statement=
show profiles;
source include/implicit_commit_helper.inc;
DROP TABLE t1;
DROP TABLE t2;
DROP TABLE t3;
eval USE $OLD_DB;
DROP DATABASE db1;
--echo End of tests