2006-08-16 14:58:49 +02:00
|
|
|
# t/handler_myisam.test
|
|
|
|
#
|
|
|
|
# test of HANDLER ...
|
|
|
|
#
|
|
|
|
# Last update:
|
|
|
|
# 2006-07-31 ML test refactored (MySQL 5.1)
|
|
|
|
# code of t/handler.test and t/innodb_handler.test united
|
2011-01-10 23:22:40 +02:00
|
|
|
# main testing code put into handler.inc
|
2006-08-16 14:58:49 +02:00
|
|
|
# rename t/handler.test to t/handler_myisam.test
|
|
|
|
#
|
|
|
|
|
|
|
|
let $engine_type= MyISAM;
|
|
|
|
|
2011-01-10 23:22:40 +02:00
|
|
|
--source init.inc
|
|
|
|
--source handler.inc
|
2009-08-21 10:55:35 +05:00
|
|
|
|
|
|
|
--echo #
|
|
|
|
--echo # BUG #46456: HANDLER OPEN + TRUNCATE + DROP (temporary) TABLE, crash
|
|
|
|
--echo #
|
|
|
|
CREATE TABLE t1 AS SELECT 1 AS f1;
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
TRUNCATE t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
|
|
|
CREATE TEMPORARY TABLE t1 AS SELECT 1 AS f1;
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
TRUNCATE t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
2010-06-09 14:45:04 +04:00
|
|
|
--echo #
|
|
|
|
--echo # Bug #54007: assert in ha_myisam::index_next , HANDLER
|
|
|
|
--echo #
|
|
|
|
CREATE TABLE t1(a INT, b INT, PRIMARY KEY(a), KEY b(b), KEY ab(a, b));
|
|
|
|
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
HANDLER t1 READ `PRIMARY` NEXT;
|
|
|
|
HANDLER t1 READ ab NEXT;
|
|
|
|
HANDLER t1 READ b NEXT;
|
|
|
|
HANDLER t1 READ NEXT;
|
|
|
|
HANDLER t1 CLOSE;
|
|
|
|
|
|
|
|
INSERT INTO t1 VALUES (2, 20), (1, 10), (4, 40), (3, 30);
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
HANDLER t1 READ NEXT;
|
|
|
|
HANDLER t1 READ `PRIMARY` NEXT;
|
|
|
|
HANDLER t1 READ `PRIMARY` NEXT;
|
|
|
|
HANDLER t1 READ ab NEXT;
|
|
|
|
HANDLER t1 READ ab NEXT;
|
|
|
|
HANDLER t1 READ b NEXT;
|
|
|
|
HANDLER t1 READ b NEXT;
|
|
|
|
HANDLER t1 READ b NEXT;
|
|
|
|
HANDLER t1 READ b NEXT;
|
|
|
|
HANDLER t1 READ b NEXT;
|
|
|
|
HANDLER t1 READ NEXT;
|
|
|
|
HANDLER t1 READ NEXT;
|
|
|
|
HANDLER t1 READ NEXT;
|
|
|
|
HANDLER t1 CLOSE;
|
|
|
|
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
HANDLER t1 READ `PRIMARY` PREV;
|
|
|
|
HANDLER t1 READ `PRIMARY` PREV;
|
|
|
|
HANDLER t1 READ b PREV;
|
|
|
|
HANDLER t1 READ b PREV;
|
|
|
|
HANDLER t1 CLOSE;
|
|
|
|
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
HANDLER t1 READ `PRIMARY` PREV LIMIT 3;
|
|
|
|
HANDLER t1 READ b NEXT LIMIT 5;
|
|
|
|
HANDLER t1 CLOSE;
|
|
|
|
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
|
|
|
|
2013-09-20 13:12:53 +04:00
|
|
|
--echo #
|
|
|
|
--echo # Additional coverage for refactoring which is made as part
|
|
|
|
--echo # of fix for bug #27480 "Extend CREATE TEMPORARY TABLES privilege
|
|
|
|
--echo # to allow temp table operations".
|
|
|
|
--echo #
|
|
|
|
--echo # Check that DDL on temporary table properly closes HANDLER cursors
|
|
|
|
--echo # for this table belonging to the same connection.
|
|
|
|
|
|
|
|
CREATE TEMPORARY TABLE t1 AS SELECT 1 AS f1;
|
|
|
|
|
|
|
|
--echo # -- CREATE TABLE
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
CREATE TEMPORARY TABLE IF NOT EXISTS t1 SELECT 1 AS f1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- REPAIR TABLE
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
REPAIR TABLE t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- ANALYZE TABLE
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
ANALYZE TABLE t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- OPTIMIZE TABLE
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
OPTIMIZE TABLE t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- CHECK TABLE
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
CHECK TABLE t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- ALTER TABLE
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
ALTER TABLE t1 ADD COLUMN b INT;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- CREATE INDEX
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
CREATE INDEX b ON t1 (b);
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- DROP INDEX
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
DROP INDEX b ON t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- TRUNCATE TABLE
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
TRUNCATE TABLE t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- DROP TABLE
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
DROP TABLE t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
CREATE TEMPORARY TABLE t1(a INT, b INT, INDEX i(a));
|
|
|
|
|
|
|
|
set global keycache1.key_cache_block_size=2048;
|
|
|
|
set global keycache1.key_buffer_size=1*1024*1024;
|
|
|
|
set global keycache1.key_buffer_size=1024*1024;
|
|
|
|
|
|
|
|
--echo # -- CACHE INDEX
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
CACHE INDEX t1 IN keycache1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
--echo # -- LOAD INDEX
|
|
|
|
HANDLER t1 OPEN;
|
|
|
|
LOAD INDEX INTO CACHE t1;
|
|
|
|
--error ER_UNKNOWN_TABLE
|
|
|
|
HANDLER t1 READ FIRST;
|
|
|
|
|
|
|
|
|
2009-08-21 10:55:35 +05:00
|
|
|
--echo End of 5.1 tests
|