mirror of
https://github.com/MariaDB/server.git
synced 2025-10-24 00:27:49 +02:00

Global temporary table (GTT) is a table with globally defined metadata, but per-session data. That is, the life duration of this data is limited with session duration. Here we have two options: 1. ON COMMIT DELETE ROWS: a default option. The life duration of data is transaction duration. 2. ON COMMIT PRESERVE ROWS: The life duration of data is session duration. # Implementation The implementation consists of the following fundamental parts. ## Part 1: CREATE TABLE + frm format 1. Store GLOBAL TEMPORARY and ON COMMIT bits in create_info->table_options 2. Store higher word of create_info->table_options in frm header 3. Also disallow ON COMMIT keyword for (local) temporary tables As a result, the bits will be available in share->db_create_options. New Table_type enum element: TABLE_TYPE_GLOBAL_TEMPORARY (datadict.h) ## Part 2: open_table: a local data table is created on demand On open, a session-local temporary table copy is created from a global TABLE_SHARE. Let us refer to the former as "local data table of GTT", and the latter as "global metadata table of GTT". There is a number of cases, when a global metadata table is opened instead, like ALTER, DROP, SHOW CREATE A local data table holds: 1. A reference to that share, and holds the increased tdc reference count. 2. An explicit MDL lock to the duration of local copy's existence. While at least one local data table exists (2) guarantees that ALTER, DROP or RENAME will not happen. (1) guarantees that a global metadata table will not be flushed At an implementation level, a local data table is a temporary table, invisible for a user and augmented with (1) and (2). The reference and lock are released upon dropping this local data table, which happens due to: a) TRUNCATE TABLE b) Connection close c) If ON COMMIT DELETE ROWS is used, then on transaction commit/rollback ## Part 3: ALTER, DROP, RENAME These operations always open a real global temporary table. ALTER, RENAME and DROP TABLE require all local data tables to be destroyed, thus, having no references to a modified/deleted table. For that, they: 1. acquire an EXCLUSIVE MDL lock. To match oracle behavior, lock_wait_timeout is 0 in ALTER TABLE. 2. Check that there is no matching local temporary table in the same connection (which is not guaranteed by 1) ## Part 4 ON COMMIT DELETE ROWS This clause is assumed by default, i.e. it is implicit. When ON COMMIT DELETE ROWS, the local data table is dropped on commit/rollback. On table open, global_temporary_tables handlerton is injected, implementing this behavior. # Limitations The following is forbidden for GTT: system versioning partitioning fk ONLINE ALTER CREATE GLOBAL TEMPORARY under LOCK TABLES FLUSH TABLE on Global temporary table is no-op for now # Refactorings, details 1. Extract drop_tmp_table_share (temporary_tables.cc) 2. Extract THD::open_temporary_table_impl (temporary_tables.cc) 3. information_schema support: x) "GLOBAL TEMPORARY" type is show in information_schema.tables y) an artifical temporary table is hidden from SHOW TABLE STATUS 4. VIEWs are supported. 5. AS SELECT support x) Made in Oracle style, so that the data is only inserted in the session that creates GTT y) ON COMMIT DELETE ROWS inserts the data for real, and then deletes the data table on implicit commit 6. CREATE TABLE ... LIKE is supported. 7. Replication support x) Set share->table_creation_was_logged to 0 to make the table ignored for replication. y) Statements with GTT involved will be logged in Row-based style (RBR) z) Global temporary table creation and alter/drop will be logged.
71 lines
2 KiB
C++
71 lines
2 KiB
C++
#ifndef SQL_TRUNCATE_INCLUDED
|
|
#define SQL_TRUNCATE_INCLUDED
|
|
/* Copyright (c) 2010, 2014, 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-1335 USA */
|
|
|
|
class THD;
|
|
struct TABLE_LIST;
|
|
|
|
/**
|
|
Sql_cmd_truncate_table represents the TRUNCATE statement.
|
|
*/
|
|
class Sql_cmd_truncate_table : public Sql_cmd
|
|
{
|
|
private:
|
|
/* Set if a lock must be downgraded after truncate is done. */
|
|
MDL_ticket *m_ticket_downgrade;
|
|
|
|
public:
|
|
/**
|
|
Constructor, used to represent a TRUNCATE statement.
|
|
*/
|
|
Sql_cmd_truncate_table() = default;
|
|
|
|
virtual ~Sql_cmd_truncate_table() = default;
|
|
|
|
/**
|
|
Execute a TRUNCATE statement at runtime.
|
|
@param thd the current thread.
|
|
@return false on success.
|
|
*/
|
|
bool execute(THD *thd) override;
|
|
|
|
enum_sql_command sql_command_code() const override
|
|
{
|
|
return SQLCOM_TRUNCATE;
|
|
}
|
|
|
|
protected:
|
|
enum truncate_result{
|
|
TRUNCATE_OK=0,
|
|
TRUNCATE_FAILED_BUT_BINLOG,
|
|
TRUNCATE_FAILED_SKIP_BINLOG
|
|
};
|
|
|
|
/** Handle locking a base table for truncate. */
|
|
bool lock_table(THD *, TABLE_LIST *, bool *, bool *);
|
|
|
|
/** Truncate table via the handler method. */
|
|
enum truncate_result handler_truncate(THD *, TABLE_LIST *, bool);
|
|
|
|
/**
|
|
Optimized delete of all rows by doing a full regenerate of the table.
|
|
Depending on the storage engine, it can be accomplished through a
|
|
drop and recreate or via the handler truncate method.
|
|
*/
|
|
bool truncate_table(THD *, TABLE_LIST *);
|
|
};
|
|
|
|
#endif
|