36
36
TableList *first_table= (TableList *) session->lex->select_lex.table_list.first;
37
37
TableList *all_tables= session->lex->query_tables;
38
38
assert(first_table == all_tables && first_table != 0);
39
Select_Lex *select_lex= &session->lex->select_lex;
40
Select_Lex_Unit *unit= &session->lex->unit;
39
41
bool need_start_waiting= false;
40
lex_identified_temp_table= createTableMessage().type() == message::Table::TEMPORARY;
42
is_engine_set= not createTableMessage().engine().name().empty();
43
bool link_to_local= false;
44
bool lex_identified_temp_table=
45
create_table_message.type() == message::Table::TEMPORARY;
46
create_info().db_type=
47
plugin::StorageEngine::findByName(*session, createTableMessage().engine().name());
50
plugin::StorageEngine::findByName(*session, create_table_message.engine().name());
49
if (create_info().db_type == NULL)
52
if (create_info.db_type == NULL)
51
54
my_error(ER_UNKNOWN_STORAGE_ENGINE, MYF(0),
52
createTableMessage().engine().name().c_str());
55
create_table_message.engine().name().c_str());
57
60
else /* We now get the default, place it in create_info, and put the engine name in table proto */
59
create_info().db_type= session->getDefaultStorageEngine();
62
create_info.db_type= session->getDefaultStorageEngine();
62
65
if (not validateCreateTableOption())
76
79
/* Skip first table, which is the table we are creating */
77
create_table_list= session->lex->unlink_first_table(&link_to_local);
79
drizzled::message::table::init(createTableMessage(), createTableMessage().name(), create_table_list->getSchemaName(), create_info().db_type->getName());
81
identifier::Table new_table_identifier(create_table_list->getSchemaName(),
80
TableList *create_table_list= session->lex->unlink_first_table(&link_to_local);
81
TableList *select_tables= session->lex->query_tables;
83
drizzled::message::init(create_table_message, create_table_message.name(), create_table_list->getSchemaName(), create_info.db_type->getName());
85
TableIdentifier new_table_identifier(create_table_list->getSchemaName(),
82
86
create_table_list->getTableName(),
83
createTableMessage().type());
87
create_table_message.type());
85
89
if (not check(new_table_identifier))
115
bool res= executeInner(new_table_identifier);
118
Release the protection against the global read lock and wake
119
everyone, who might want to set a global read lock.
121
session->startWaitingGlobalReadLock();
126
bool statement::CreateTable::executeInner(identifier::Table::const_reference new_table_identifier)
129
Select_Lex *select_lex= &session->lex->select_lex;
130
TableList *select_tables= session->lex->query_tables;
119
if (select_lex->item_list.elements) // With select
134
if (select_lex->item_list.elements) // With select
136
Select_Lex_Unit *unit= &session->lex->unit;
137
select_result *result;
139
select_lex->options|= SELECT_NO_UNLOCK;
140
unit->set_limit(select_lex);
121
select_result *result;
123
select_lex->options|= SELECT_NO_UNLOCK;
124
unit->set_limit(select_lex);
126
if (not lex_identified_temp_table)
128
session->lex->link_first_table_back(create_table_list, link_to_local);
129
create_table_list->setCreate(true);
132
if (not (res= session->openTablesLock(session->lex->query_tables)))
135
Is table which we are changing used somewhere in other parts
142
138
if (not lex_identified_temp_table)
144
session->lex->link_first_table_back(create_table_list, link_to_local);
145
create_table_list->setCreate(true);
148
if (not (res= session->openTablesLock(session->lex->query_tables)))
151
Is table which we are changing used somewhere in other parts
154
if (not lex_identified_temp_table)
156
TableList *duplicate= NULL;
157
create_table_list= session->lex->unlink_first_table(&link_to_local);
159
if ((duplicate= unique_table(create_table_list, select_tables)))
161
my_error(ER_UPDATE_TABLE_USED, MYF(0), create_table_list->alias);
162
/* put tables back for PS rexecuting */
163
session->lex->link_first_table_back(create_table_list, link_to_local);
171
select_create is currently not re-execution friendly and
172
needs to be created for every execution of a PS/SP.
174
if ((result= new select_create(create_table_list,
175
session->getLex()->exists(),
177
createTableMessage(),
179
select_lex->item_list,
180
session->lex->duplicates,
181
session->lex->ignore,
183
new_table_identifier)))
140
TableList *duplicate= NULL;
141
create_table_list= session->lex->unlink_first_table(&link_to_local);
142
if ((duplicate= unique_table(create_table_list, select_tables)))
144
my_error(ER_UPDATE_TABLE_USED, MYF(0), create_table_list->alias);
186
CREATE from SELECT give its Select_Lex for SELECT,
187
and item_list belong to SELECT
189
res= handle_select(session, session->lex, result, 0);
146
Release the protection against the global read lock and wake
147
everyone, who might want to set a global read lock.
149
session->startWaitingGlobalReadLock();
150
/* put tables back for PS rexecuting */
151
session->lex->link_first_table_back(create_table_list, link_to_local);
193
else if (not lex_identified_temp_table)
158
select_create is currently not re-execution friendly and
159
needs to be created for every execution of a PS/SP.
161
if ((result= new select_create(create_table_list,
164
create_table_message,
166
select_lex->item_list,
167
session->lex->duplicates,
168
session->lex->ignore,
170
new_table_identifier)))
195
create_table_list= session->lex->unlink_first_table(&link_to_local);
173
CREATE from SELECT give its Select_Lex for SELECT,
174
and item_list belong to SELECT
176
res= handle_select(session, session->lex, result, 0);
180
else if (not lex_identified_temp_table)
182
create_table_list= session->lex->unlink_first_table(&link_to_local);
188
if (is_create_table_like)
190
res= create_like_table(session,
191
new_table_identifier,
194
create_table_message,
201
if (is_create_table_like)
203
res= create_like_table(session,
204
new_table_identifier,
205
identifier::Table(select_tables->getSchemaName(),
206
select_tables->getTableName()),
207
createTableMessage(),
208
session->getLex()->exists(),
214
for (int32_t x= 0; x < alter_info.alter_proto.added_field_size(); x++)
216
message::Table::Field *field= createTableMessage().add_field();
218
*field= alter_info.alter_proto.added_field(x);
221
res= create_table(session,
222
new_table_identifier,
224
createTableMessage(),
228
session->getLex()->exists());
201
for (int32_t x= 0; x < alter_info.alter_proto.added_field_size(); x++)
203
message::Table::Field *field= create_table_message.add_field();
205
*field= alter_info.alter_proto.added_field(x);
208
res= create_table(session,
209
new_table_identifier,
211
create_table_message,
225
Release the protection against the global read lock and wake
226
everyone, who might want to set a global read lock.
228
session->startWaitingGlobalReadLock();
241
bool statement::CreateTable::check(const identifier::Table &identifier)
233
bool statement::CreateTable::check(const TableIdentifier &identifier)
243
235
// Check table name for validity
244
236
if (not identifier.isValid())
267
259
bool statement::CreateTable::validateCreateTableOption()
270
size_t num_engine_options= createTableMessage().engine().options_size();
262
size_t num_engine_options= create_table_message.engine().options_size();
272
assert(create_info().db_type);
264
assert(create_info.db_type);
274
266
for (size_t y= 0; y < num_engine_options; ++y)
276
bool valid= create_info().db_type->validateCreateTableOption(createTableMessage().engine().options(y).name(),
277
createTableMessage().engine().options(y).state());
268
bool valid= create_info.db_type->validateCreateTableOption(create_table_message.engine().options(y).name(),
269
create_table_message.engine().options(y).state());
281
273
my_error(ER_UNKNOWN_ENGINE_OPTION, MYF(0),
282
createTableMessage().engine().options(y).name().c_str(),
283
createTableMessage().engine().options(y).state().c_str());
274
create_table_message.engine().options(y).name().c_str(),
275
create_table_message.engine().options(y).state().c_str());