mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
Bug#49907: ALTER TABLE ... TRUNCATE PARTITION does not wait for
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.
This commit is contained in:
139
sql/sql_partition_admin.cc
Normal file
139
sql/sql_partition_admin.cc
Normal file
@ -0,0 +1,139 @@
|
||||
/* Copyright (c) 2010 Oracle and/or its affiliates. All rights reserved.
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; version 2 of the License.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
|
||||
|
||||
#include "sql_parse.h" // check_one_table_access
|
||||
#include "sql_table.h" // mysql_alter_table, etc.
|
||||
#include "sql_lex.h" // Sql_statement
|
||||
#include "sql_truncate.h" // mysql_truncate_table,
|
||||
// Truncate_statement
|
||||
#include "sql_table_maintenance.h" // Analyze/Check/.._table_statement
|
||||
#include "sql_partition_admin.h" // Alter_table_*_partition
|
||||
|
||||
#ifndef WITH_PARTITION_STORAGE_ENGINE
|
||||
|
||||
bool Partition_statement_unsupported::execute(THD *)
|
||||
{
|
||||
DBUG_ENTER("Partition_statement_unsupported::execute");
|
||||
/* error, partitioning support not compiled in... */
|
||||
my_error(ER_FEATURE_DISABLED, MYF(0), "partitioning",
|
||||
"--with-plugin-partition");
|
||||
DBUG_RETURN(TRUE);
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
bool Alter_table_analyze_partition_statement::execute(THD *thd)
|
||||
{
|
||||
bool res;
|
||||
DBUG_ENTER("Alter_table_analyze_partition_statement::execute");
|
||||
|
||||
/*
|
||||
Flag that it is an ALTER command which administrates partitions, used
|
||||
by ha_partition
|
||||
*/
|
||||
m_lex->alter_info.flags|= ALTER_ADMIN_PARTITION;
|
||||
|
||||
res= Analyze_table_statement::execute(thd);
|
||||
|
||||
DBUG_RETURN(res);
|
||||
}
|
||||
|
||||
|
||||
bool Alter_table_check_partition_statement::execute(THD *thd)
|
||||
{
|
||||
bool res;
|
||||
DBUG_ENTER("Alter_table_check_partition_statement::execute");
|
||||
|
||||
/*
|
||||
Flag that it is an ALTER command which administrates partitions, used
|
||||
by ha_partition
|
||||
*/
|
||||
m_lex->alter_info.flags|= ALTER_ADMIN_PARTITION;
|
||||
|
||||
res= Check_table_statement::execute(thd);
|
||||
|
||||
DBUG_RETURN(res);
|
||||
}
|
||||
|
||||
|
||||
bool Alter_table_optimize_partition_statement::execute(THD *thd)
|
||||
{
|
||||
bool res;
|
||||
DBUG_ENTER("Alter_table_optimize_partition_statement::execute");
|
||||
|
||||
/*
|
||||
Flag that it is an ALTER command which administrates partitions, used
|
||||
by ha_partition
|
||||
*/
|
||||
m_lex->alter_info.flags|= ALTER_ADMIN_PARTITION;
|
||||
|
||||
res= Optimize_table_statement::execute(thd);
|
||||
|
||||
DBUG_RETURN(res);
|
||||
}
|
||||
|
||||
|
||||
bool Alter_table_repair_partition_statement::execute(THD *thd)
|
||||
{
|
||||
bool res;
|
||||
DBUG_ENTER("Alter_table_repair_partition_statement::execute");
|
||||
|
||||
/*
|
||||
Flag that it is an ALTER command which administrates partitions, used
|
||||
by ha_partition
|
||||
*/
|
||||
m_lex->alter_info.flags|= ALTER_ADMIN_PARTITION;
|
||||
|
||||
res= Repair_table_statement::execute(thd);
|
||||
|
||||
DBUG_RETURN(res);
|
||||
}
|
||||
|
||||
|
||||
bool Alter_table_truncate_partition_statement::execute(THD *thd)
|
||||
{
|
||||
TABLE_LIST *first_table= thd->lex->select_lex.table_list.first;
|
||||
bool res;
|
||||
enum_sql_command original_sql_command;
|
||||
DBUG_ENTER("Alter_table_truncate_partition_statement::execute");
|
||||
|
||||
/*
|
||||
Execute TRUNCATE PARTITION just like TRUNCATE TABLE.
|
||||
Some storage engines (InnoDB, partition) checks thd_sql_command,
|
||||
so we set it to SQLCOM_TRUNCATE during the execution.
|
||||
*/
|
||||
original_sql_command= m_lex->sql_command;
|
||||
m_lex->sql_command= SQLCOM_TRUNCATE;
|
||||
|
||||
/*
|
||||
Flag that it is an ALTER command which administrates partitions, used
|
||||
by ha_partition.
|
||||
*/
|
||||
m_lex->alter_info.flags|= ALTER_ADMIN_PARTITION;
|
||||
|
||||
/*
|
||||
Fix the lock types (not the same as ordinary ALTER TABLE).
|
||||
*/
|
||||
first_table->lock_type= TL_WRITE;
|
||||
first_table->mdl_request.set_type(MDL_SHARED_NO_READ_WRITE);
|
||||
|
||||
/* execute as a TRUNCATE TABLE */
|
||||
res= Truncate_statement::execute(thd);
|
||||
|
||||
m_lex->sql_command= original_sql_command;
|
||||
DBUG_RETURN(res);
|
||||
}
|
||||
|
||||
#endif /* WITH_PARTITION_STORAGE_ENGINE */
|
Reference in New Issue
Block a user