-
Notifications
You must be signed in to change notification settings - Fork 4k
/
Copy pathtablespace.h
252 lines (189 loc) · 8.32 KB
/
tablespace.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
/* Copyright (c) 2014, 2025, Oracle and/or its affiliates.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License, version 2.0,
as published by the Free Software Foundation.
This program is designed to work with certain software (including
but not limited to OpenSSL) that is licensed under separate terms,
as designated in a particular file or component or in included license
documentation. The authors of MySQL hereby grant you an additional
permission to link the program and your derivative works with the
separately licensed software that they have either included with
the program or referenced in the documentation.
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, version 2.0, 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 */
#ifndef DD__TABLESPACE_INCLUDED
#define DD__TABLESPACE_INCLUDED
#include <vector>
#include "lex_string.h"
#include "my_inttypes.h"
#include "sql/dd/collection.h" // dd::Collection
#include "sql/dd/impl/raw/object_keys.h" // IWYU pragma: keep
#include "sql/dd/sdi_fwd.h" // RJ_Document
#include "sql/dd/types/entity_object.h" // dd::Entity_object
#include "sql/mdl.h" // enum enum_mdl_type
class THD;
class MDL_request;
namespace dd {
///////////////////////////////////////////////////////////////////////////
class Global_name_key;
class Properties;
class Tablespace_impl;
class Tablespace_file;
class Void_key;
namespace tables {
class Tablespaces;
}
///////////////////////////////////////////////////////////////////////////
class Tablespace : virtual public Entity_object {
public:
typedef Tablespace_impl Impl;
typedef Tablespace Cache_partition;
typedef tables::Tablespaces DD_table;
typedef Primary_id_key Id_key;
typedef Global_name_key Name_key;
typedef Void_key Aux_key;
typedef Collection<Tablespace_file *> Tablespace_file_collection;
// We need a set of functions to update a preallocated key.
virtual bool update_id_key(Id_key *key) const {
return update_id_key(key, id());
}
static bool update_id_key(Id_key *key, Object_id id);
virtual bool update_name_key(Name_key *key) const {
return update_name_key(key, name());
}
static bool update_name_key(Name_key *key, const String_type &name);
virtual bool update_aux_key(Aux_key *) const { return true; }
public:
~Tablespace() override = default;
/**
Check if the tablespace is empty, i.e., whether it has any tables.
@param thd Thread context.
@param [out] empty Whether the tablespace is empty.
@return true if error, false if success.
*/
virtual bool is_empty(THD *thd, bool *empty) const = 0;
/////////////////////////////////////////////////////////////////////////
// comment.
/////////////////////////////////////////////////////////////////////////
virtual const String_type &comment() const = 0;
virtual void set_comment(const String_type &comment) = 0;
/////////////////////////////////////////////////////////////////////////
// options.
/////////////////////////////////////////////////////////////////////////
virtual const Properties &options() const = 0;
virtual Properties &options() = 0;
virtual bool set_options(const String_type &options_raw) = 0;
/////////////////////////////////////////////////////////////////////////
// se_private_data.
/////////////////////////////////////////////////////////////////////////
virtual const Properties &se_private_data() const = 0;
virtual Properties &se_private_data() = 0;
virtual bool set_se_private_data(const String_type &se_private_data_raw) = 0;
/////////////////////////////////////////////////////////////////////////
// Engine.
/////////////////////////////////////////////////////////////////////////
virtual const String_type &engine() const = 0;
virtual void set_engine(const String_type &engine) = 0;
/////////////////////////////////////////////////////////////////////////
// SE-specific json attributes
/////////////////////////////////////////////////////////////////////////
virtual LEX_CSTRING engine_attribute() const = 0;
virtual void set_engine_attribute(LEX_CSTRING a) = 0;
/////////////////////////////////////////////////////////////////////////
// Tablespace file collection.
/////////////////////////////////////////////////////////////////////////
virtual Tablespace_file *add_file() = 0;
virtual bool remove_file(String_type data_file) = 0;
virtual const Tablespace_file_collection &files() const = 0;
/**
Allocate a new object graph and invoke the copy constructor for
each object.
@return pointer to dynamically allocated copy
*/
virtual Tablespace *clone() const = 0;
/**
Allocate a new object which can serve as a placeholder for the original
object in the Dictionary_client's dropped registry. Such object has the
same keys as the original but has no other info and as result occupies
less memory.
*/
virtual Tablespace *clone_dropped_object_placeholder() const = 0;
/**
Converts *this into json.
Converts all member variables that are to be included in the sdi
into json by transforming them appropriately and passing them to
the rapidjson writer provided.
@param wctx opaque context for data needed by serialization
@param w rapidjson writer which will perform conversion to json
*/
virtual void serialize(Sdi_wcontext *wctx, Sdi_writer *w) const = 0;
/**
Re-establishes the state of *this by reading sdi information from
the rapidjson DOM subobject provided.
Cross-references encountered within this object are tracked in
sdictx, so that they can be updated when the entire object graph
has been established.
@param rctx stores book-keeping information for the
deserialization process
@param val subobject of rapidjson DOM containing json
representation of this object
*/
virtual bool deserialize(Sdi_rcontext *rctx, const RJ_Value &val) = 0;
};
///////////////////////////////////////////////////////////////////////////
/**
Represents tables with their id, name, schema id and schema name.
Needed to keep track of information when querying the dd to find
tables in a tablespace.
*/
struct Tablespace_table_ref {
Object_id m_id;
String_type m_name;
Object_id m_schema_id;
String_type m_schema_name;
bool m_schema_encryption;
Tablespace_table_ref() = default; /* purecov: inspected */
Tablespace_table_ref(Object_id id, const String_type &&name,
Object_id schema_id)
: m_id{id},
m_name{std::move(name)},
m_schema_id{schema_id},
m_schema_encryption{false} {}
};
bool operator==(const Tablespace_table_ref &a, const Tablespace_table_ref &b);
bool operator<(const Tablespace_table_ref &a, const Tablespace_table_ref &b);
typedef std::vector<Tablespace_table_ref> Tablespace_table_ref_vec;
/**
Fetch (by inserting into tblref vector) Tablespace_table_ref objects
which describe tables in a given tablespace.
@param thd thread context
@param tso dd object
@param tblrefs [OUT] Tablespace_table_ref objects for tables in tablespace
@retval true if error occurred
@retval false otherwise
*/
bool fetch_tablespace_table_refs(THD *thd, const Tablespace &tso,
Tablespace_table_ref_vec *tblrefs);
/**
Create am MDL_request for a the table identified by a Tablespace_table_ref.
@param thd thread context
@param tref table to create request for
@param mdl_type The lock type requested.
@retval MDL_request (allocated on thd->memroot)
*/
MDL_request *mdl_req(THD *thd, const Tablespace_table_ref &tref,
enum enum_mdl_type mdl_type);
/**
Create am MDL_request for a the schema name provided.
@param thd thread context
@param schema_name on which to create request for
@retval MDL_request (allocated on thd->memroot)
*/
MDL_request *mdl_schema_req(THD *thd, const dd::String_type &schema_name);
} // namespace dd
#endif // DD__TABLESPACE_INCLUDED