1
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2009 Sun Microsystems
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation; either version 2 of the License, or
9
* (at your option) any later version.
11
* This program is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU General Public License for more details.
16
* You should have received a copy of the GNU General Public License
17
* along with this program; if not, write to the Free Software
18
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
23
* table constraints I_S table methods.
26
#include "drizzled/server_includes.h"
27
#include "drizzled/session.h"
28
#include "drizzled/show.h"
30
#include "helper_methods.h"
31
#include "table_constraints.h"
35
using namespace drizzled;
39
* Vectors of columns for the table constraints I_S table.
41
static vector<const plugin::ColumnInfo *> *columns= NULL;
44
* Methods for the table constraints I_S table.
46
static plugin::InfoSchemaMethods *methods= NULL;
49
* table constraints I_S table.
51
static plugin::InfoSchemaTable *tc_table= NULL;
54
* Populate the vectors of columns for the I_S table.
56
* @return a pointer to a std::vector of Columns.
58
vector<const plugin::ColumnInfo *> *TableConstraintsIS::createColumns()
62
columns= new vector<const plugin::ColumnInfo *>;
66
clearColumns(*columns);
69
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_CATALOG",
77
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_SCHEMA",
85
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_NAME",
93
columns->push_back(new plugin::ColumnInfo("TABLE_SCHEMA",
101
columns->push_back(new plugin::ColumnInfo("TABLE_NAME",
103
DRIZZLE_TYPE_VARCHAR,
109
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_TYPE",
111
DRIZZLE_TYPE_VARCHAR,
120
* Initialize the I_S table.
122
* @return a pointer to an I_S table
124
plugin::InfoSchemaTable *TableConstraintsIS::getTable()
126
columns= createColumns();
130
methods= new TabConstraintsISMethods();
133
if (tc_table == NULL)
135
tc_table= new plugin::InfoSchemaTable("TABLE_CONSTRAINTS",
146
* Delete memory allocated for the table, columns and methods.
148
void TableConstraintsIS::cleanup()
150
clearColumns(*columns);
156
static bool store_constraints(Session *session,
159
LEX_STRING *table_name,
160
const char *key_name,
162
const char *con_type,
165
const CHARSET_INFO * const cs= system_charset_info;
166
table->restoreRecordAsDefault();
167
table->field[1]->store(db_name->str, db_name->length, cs);
168
table->field[2]->store(key_name, key_len, cs);
169
table->field[3]->store(db_name->str, db_name->length, cs);
170
table->field[4]->store(table_name->str, table_name->length, cs);
171
table->field[5]->store(con_type, con_len, cs);
172
return schema_table_store_record(session, table);
175
int TabConstraintsISMethods::processTable(Session *session,
180
LEX_STRING *table_name) const
184
if (session->is_error())
186
push_warning(session,
187
DRIZZLE_ERROR::WARN_LEVEL_WARN,
188
session->main_da.sql_errno(),
189
session->main_da.message());
191
session->clear_error();
196
List<FOREIGN_KEY_INFO> f_key_list;
197
Table *show_table= tables->table;
198
KEY *key_info=show_table->key_info;
199
uint32_t primary_key= show_table->s->primary_key;
200
show_table->cursor->info(HA_STATUS_VARIABLE |
203
for (uint32_t i= 0; i < show_table->s->keys; i++, key_info++)
205
if (i != primary_key && ! (key_info->flags & HA_NOSAME))
210
if (i == primary_key && is_primary_key(key_info))
212
if (store_constraints(session,
217
strlen(key_info->name),
218
STRING_WITH_LEN("PRIMARY KEY")))
223
else if (key_info->flags & HA_NOSAME)
225
if (store_constraints(session,
230
strlen(key_info->name),
231
STRING_WITH_LEN("UNIQUE")))
238
show_table->cursor->get_foreign_key_list(session, &f_key_list);
239
FOREIGN_KEY_INFO *f_key_info= NULL;
240
List_iterator_fast<FOREIGN_KEY_INFO> it(f_key_list);
241
while ((f_key_info= it++))
243
if (store_constraints(session,
247
f_key_info->forein_id->str,
248
strlen(f_key_info->forein_id->str),