mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 13:02:28 +01:00
4b20ccafaa
locks on the table Fixing the partitioning specifics after TRUNCATE TABLE in bug-42643 was fixed. Reorganize of code to decrease the size of the giant switch in mysql_execute_command, and to prepare for future parser reengineering. Moved code into Sql_statement objects. Updated patch according to davi's review comments. libmysqld/CMakeLists.txt: Added new files. libmysqld/Makefile.am: Added new files. mysql-test/r/not_partition.result: now returning error on partitioning commands if partitioning is not enabled. mysql-test/r/partition_disabled.result: There is no partition handlerton, so it cannot find the specified engine in the .frm file. mysql-test/r/partition_truncate.result: Updated test results. mysql-test/suite/parts/inc/partition_mgm.inc: Added check that TRUNCATE PARTITION does not delete on failure. mysql-test/suite/parts/r/partition_debug_sync_innodb.result: updated results. mysql-test/suite/parts/r/partition_mgm_lc0_archive.result: updated results. mysql-test/suite/parts/r/partition_mgm_lc1_archive.result: updated results. mysql-test/suite/parts/r/partition_mgm_lc2_archive.result: updated results. mysql-test/suite/parts/t/partition_debug_sync_innodb.test: Test case for this bug. mysql-test/t/not_partition.test: Added check for TRUNCATE PARTITION without partitioning. mysql-test/t/partition_truncate.test: Added test of TRUNCATE PARTITION on non partitioned table. sql/CMakeLists.txt: Added new files. sql/Makefile.am: Added new files. sql/datadict.cc: Moved out the storage engine check into an own function, including assert for lock. sql/datadict.h: added dd_frm_storage_engine. sql/sql_alter_table.cc: moved the code for SQLCOM_ALTER_TABLE in mysql_execute_command into its own file, and using the Sql_statement object to prepare for future parser reengineering. sql/sql_alter_table.h: Created Sql_statement object for ALTER TABLE. sql/sql_lex.cc: resetting m_stmt. sql/sql_lex.h: Temporary hack for forward declaration of enum_alter_table_change_level. sql/sql_parse.cc: Moved out ALTER/ANALYZE/CHECK/OPTIMIZE/REPAIR TABLE from the giant switch into their own Sql_statement objects. sql/sql_parse.h: Exporting check_merge_table_access. sql/sql_partition_admin.cc: created Sql_statement for ALTER TABLE t ANALYZE/CHECK/OPTIMIZE/REPAIR/TRUNCATE PARTITION. To be able to reuse the TABLE equivalents. sql/sql_partition_admin.h: Added Sql_statement of partition admin statements. sql/sql_table.cc: Moved table maintenance code into sql_table_maintenance.cc sql/sql_table.h: Moved table maintenance code into sql_table_maintenance.h exporting functions used by sql_table_maintenance. sql/sql_table_maintenance.cc: Moved table maintenance code from sql_table.cc sql/sql_table_maintenance.h: Sql_statement objects for ANALYZE/CHECK/OPTIMIZE/REPAIR TABLE. Also declaring the keycache functions. sql/sql_truncate.cc: Moved code from SQLCOM_TRUNCATE in mysql_execute_command into Truncate_statement::execute. Added check for partitioned table on TRUNCATE PARTITION. Moved locking fix for partitioned table into Alter_table_truncate_partition::execute. sql/sql_truncate.h: Truncate_statement declaration (sub class of Sql_statement). sql/sql_yacc.yy: Using the new Sql_statment objects.
93 lines
4 KiB
Text
93 lines
4 KiB
Text
DROP TABLE IF EXISTS t1;
|
|
FLUSH TABLES;
|
|
SELECT * FROM t1;
|
|
ERROR HY000: The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
TRUNCATE TABLE t1;
|
|
ERROR 42S02: Table 'test.t1' doesn't exist
|
|
ANALYZE TABLE t1;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 analyze Error The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
test.t1 analyze error Corrupt
|
|
CHECK TABLE t1;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 check Error The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
test.t1 check error Corrupt
|
|
OPTIMIZE TABLE t1;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 optimize Error The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
test.t1 optimize error Corrupt
|
|
REPAIR TABLE t1;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 repair Error The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
test.t1 repair error Corrupt
|
|
ALTER TABLE t1 REPAIR PARTITION ALL;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 repair Error The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
test.t1 repair error Corrupt
|
|
ALTER TABLE t1 CHECK PARTITION ALL;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 check Error The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
test.t1 check error Corrupt
|
|
ALTER TABLE t1 OPTIMIZE PARTITION ALL;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 optimize Error The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
test.t1 optimize error Corrupt
|
|
ALTER TABLE t1 ANALYZE PARTITION ALL;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 analyze Error The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
test.t1 analyze error Corrupt
|
|
ALTER TABLE t1 REBUILD PARTITION ALL;
|
|
ERROR HY000: The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
ALTER TABLE t1 ENGINE Memory;
|
|
ERROR HY000: The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
ALTER TABLE t1 ADD (new INT);
|
|
ERROR HY000: The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
DROP TABLE t1;
|
|
CREATE TABLE t1 (
|
|
firstname VARCHAR(25) NOT NULL,
|
|
lastname VARCHAR(25) NOT NULL,
|
|
username VARCHAR(16) NOT NULL,
|
|
email VARCHAR(35),
|
|
joined DATE NOT NULL
|
|
)
|
|
PARTITION BY KEY(joined)
|
|
PARTITIONS 6;
|
|
ERROR HY000: The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
ALTER TABLE t1 PARTITION BY KEY(joined) PARTITIONS 2;
|
|
ERROR HY000: The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
drop table t1;
|
|
ERROR 42S02: Unknown table 't1'
|
|
CREATE TABLE t1 (
|
|
firstname VARCHAR(25) NOT NULL,
|
|
lastname VARCHAR(25) NOT NULL,
|
|
username VARCHAR(16) NOT NULL,
|
|
email VARCHAR(35),
|
|
joined DATE NOT NULL
|
|
)
|
|
PARTITION BY RANGE( YEAR(joined) ) (
|
|
PARTITION p0 VALUES LESS THAN (1960),
|
|
PARTITION p1 VALUES LESS THAN (1970),
|
|
PARTITION p2 VALUES LESS THAN (1980),
|
|
PARTITION p3 VALUES LESS THAN (1990),
|
|
PARTITION p4 VALUES LESS THAN MAXVALUE
|
|
);
|
|
ERROR HY000: The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
drop table t1;
|
|
ERROR 42S02: Unknown table 't1'
|
|
CREATE TABLE t1 (id INT, purchased DATE)
|
|
PARTITION BY RANGE( YEAR(purchased) )
|
|
SUBPARTITION BY HASH( TO_DAYS(purchased) )
|
|
SUBPARTITIONS 2 (
|
|
PARTITION p0 VALUES LESS THAN (1990),
|
|
PARTITION p1 VALUES LESS THAN (2000),
|
|
PARTITION p2 VALUES LESS THAN MAXVALUE
|
|
);
|
|
ERROR HY000: The MySQL server is running with the --skip-partition option so it cannot execute this statement
|
|
drop table t1;
|
|
ERROR 42S02: Unknown table 't1'
|
|
create table t1 (a varchar(10) charset latin1 collate latin1_bin);
|
|
insert into t1 values (''),(' '),('a'),('a '),('a ');
|
|
explain partitions select * from t1 where a='a ' OR a='a';
|
|
id select_type table partitions type possible_keys key key_len ref rows Extra
|
|
1 SIMPLE t1 NULL ALL NULL NULL NULL NULL 5 Using where
|
|
drop table t1;
|