48
48
or for an intermediate table used in ALTER.
49
49
XXX Why are internal temporary tables added to this list?
51
52
Table *temporary_tables;
55
Table *getTemporaryTables()
57
return temporary_tables;
61
Mark all temporary tables which were used by the current statement or
62
substatement as free for reuse, but only if the query_id can be cleared.
64
@param session thread context
66
@remark For temp tables associated with a open SQL HANDLER the query_id
67
is not reset until the HANDLER is closed.
69
void mark_temp_tables_as_free_for_reuse();
72
void close_temporary_tables();
74
void close_temporary_table(Table *table);
75
// The method below just handles the de-allocation of the table. In
76
// a better memory type world, this would not be needed.
78
void nukeTable(Table *table);
81
/* Work with temporary tables */
82
Table *find_temporary_table(const TableIdentifier &identifier);
84
void dumpTemporaryTableNames(const char *id);
85
int drop_temporary_table(const drizzled::TableIdentifier &identifier);
86
bool rm_temporary_table(plugin::StorageEngine *base, TableIdentifier &identifier);
87
bool rm_temporary_table(TableIdentifier &identifier, bool best_effort= false);
88
Table *open_temporary_table(TableIdentifier &identifier,
89
bool link_in_list= true);
91
virtual query_id_t getQueryId() const= 0;
53
94
Table *derived_tables;
98
Table *getDerivedTables()
100
return derived_tables;
103
void setDerivedTables(Table *arg)
108
void clearDerivedTables()
111
derived_tables= NULL; // They should all be invalid by this point
55
115
During a MySQL session, one can lock tables in two modes: automatic
56
116
or manual. In automatic mode all necessary tables are locked just before
92
152
virtual ~Open_tables_state() {}
154
void doGetTableNames(CachedDirectory &directory,
155
const SchemaIdentifier &schema_identifier,
156
std::set<std::string>& set_of_names);
157
void doGetTableNames(const SchemaIdentifier &schema_identifier,
158
std::set<std::string>& set_of_names);
160
void doGetTableIdentifiers(CachedDirectory &directory,
161
const SchemaIdentifier &schema_identifier,
162
TableIdentifiers &set_of_identifiers);
163
void doGetTableIdentifiers(const SchemaIdentifier &schema_identifier,
164
TableIdentifiers &set_of_identifiers);
166
int doGetTableDefinition(const drizzled::TableIdentifier &identifier,
167
message::Table &table_proto);
168
bool doDoesTableExist(const drizzled::TableIdentifier &identifier);
94
171
Open_tables_state(uint64_t version_arg);