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",
76
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_SCHEMA",
83
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_NAME",
90
columns->push_back(new plugin::ColumnInfo("TABLE_SCHEMA",
97
columns->push_back(new plugin::ColumnInfo("TABLE_NAME",
104
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_TYPE",
106
DRIZZLE_TYPE_VARCHAR,
114
* Initialize the I_S table.
116
* @return a pointer to an I_S table
118
plugin::InfoSchemaTable *TableConstraintsIS::getTable()
120
columns= createColumns();
124
methods= new TabConstraintsISMethods();
127
if (tc_table == NULL)
129
tc_table= new plugin::InfoSchemaTable("TABLE_CONSTRAINTS",
140
* Delete memory allocated for the table, columns and methods.
142
void TableConstraintsIS::cleanup()
144
clearColumns(*columns);
150
static bool store_constraints(Table *table,
152
LEX_STRING *table_name,
153
const char *key_name,
155
const char *con_type,
157
plugin::InfoSchemaTable *schema_table)
159
const CHARSET_INFO * const cs= system_charset_info;
160
table->restoreRecordAsDefault();
161
table->setWriteSet(1);
162
table->setWriteSet(2);
163
table->setWriteSet(3);
164
table->setWriteSet(4);
165
table->setWriteSet(5);
166
table->field[1]->store(db_name->str, db_name->length, cs);
167
table->field[2]->store(key_name, key_len, cs);
168
table->field[3]->store(db_name->str, db_name->length, cs);
169
table->field[4]->store(table_name->str, table_name->length, cs);
170
table->field[5]->store(con_type, con_len, cs);
171
schema_table->addRow(table->record[0], table->s->reclength);
175
int TabConstraintsISMethods::processTable(plugin::InfoSchemaTable *store_table,
181
LEX_STRING *table_name)
185
if (session->is_error())
187
push_warning(session,
188
DRIZZLE_ERROR::WARN_LEVEL_WARN,
189
session->main_da.sql_errno(),
190
session->main_da.message());
192
session->clear_error();
197
List<FOREIGN_KEY_INFO> f_key_list;
198
Table *show_table= tables->table;
199
KEY *key_info=show_table->key_info;
200
uint32_t primary_key= show_table->s->primary_key;
201
show_table->cursor->info(HA_STATUS_VARIABLE |
204
for (uint32_t i= 0; i < show_table->s->keys; i++, key_info++)
206
if (i != primary_key && ! (key_info->flags & HA_NOSAME))
211
if (i == primary_key && is_primary_key(key_info))
213
if (store_constraints(table,
217
strlen(key_info->name),
218
STRING_WITH_LEN("PRIMARY KEY"),
224
else if (key_info->flags & HA_NOSAME)
226
if (store_constraints(table,
230
strlen(key_info->name),
231
STRING_WITH_LEN("UNIQUE"),
239
show_table->cursor->get_foreign_key_list(session, &f_key_list);
240
FOREIGN_KEY_INFO *f_key_info= NULL;
241
List_iterator_fast<FOREIGN_KEY_INFO> it(f_key_list);
242
while ((f_key_info= it++))
244
if (store_constraints(table,
247
f_key_info->forein_id->str,
248
strlen(f_key_info->forein_id->str),