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.
27
#include "drizzled/session.h"
28
#include "drizzled/show.h"
29
#include "drizzled/sql_table.h"
30
#include "drizzled/global_charset_info.h"
33
#include "helper_methods.h"
34
#include "table_constraints.h"
38
using namespace drizzled;
42
* Vectors of columns for the table constraints I_S table.
44
static vector<const plugin::ColumnInfo *> *columns= NULL;
47
* Methods for the table constraints I_S table.
49
static plugin::InfoSchemaMethods *methods= NULL;
52
* table constraints I_S table.
54
static plugin::InfoSchemaTable *tc_table= NULL;
57
* Populate the vectors of columns for the I_S table.
59
* @return a pointer to a std::vector of Columns.
61
vector<const plugin::ColumnInfo *> *TableConstraintsIS::createColumns()
65
columns= new vector<const plugin::ColumnInfo *>;
69
clearColumns(*columns);
72
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_CATALOG",
79
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_SCHEMA",
86
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_NAME",
93
columns->push_back(new plugin::ColumnInfo("TABLE_SCHEMA",
100
columns->push_back(new plugin::ColumnInfo("TABLE_NAME",
102
DRIZZLE_TYPE_VARCHAR,
107
columns->push_back(new plugin::ColumnInfo("CONSTRAINT_TYPE",
109
DRIZZLE_TYPE_VARCHAR,
117
* Initialize the I_S table.
119
* @return a pointer to an I_S table
121
plugin::InfoSchemaTable *TableConstraintsIS::getTable()
123
columns= createColumns();
127
methods= new TabConstraintsISMethods();
130
if (tc_table == NULL)
132
tc_table= new plugin::InfoSchemaTable("OLD_TABLE_CONSTRAINTS",
143
* Delete memory allocated for the table, columns and methods.
145
void TableConstraintsIS::cleanup()
147
clearColumns(*columns);
153
static bool store_constraints(Table *table,
155
LEX_STRING *table_name,
156
const char *key_name,
158
const char *con_type,
160
plugin::InfoSchemaTable *schema_table)
162
const CHARSET_INFO * const cs= system_charset_info;
163
table->restoreRecordAsDefault();
164
table->setWriteSet(1);
165
table->setWriteSet(2);
166
table->setWriteSet(3);
167
table->setWriteSet(4);
168
table->setWriteSet(5);
169
table->field[1]->store(db_name->str, db_name->length, cs);
170
table->field[2]->store(key_name, key_len, cs);
171
table->field[3]->store(db_name->str, db_name->length, cs);
172
table->field[4]->store(table_name->str, table_name->length, cs);
173
table->field[5]->store(con_type, con_len, cs);
174
schema_table->addRow(table->record[0], table->s->reclength);
178
int TabConstraintsISMethods::processTable(plugin::InfoSchemaTable *store_table,
184
LEX_STRING *table_name)
188
if (session->is_error())
190
push_warning(session,
191
DRIZZLE_ERROR::WARN_LEVEL_WARN,
192
session->main_da.sql_errno(),
193
session->main_da.message());
195
session->clear_error();
200
List<FOREIGN_KEY_INFO> f_key_list;
201
Table *show_table= tables->table;
202
KEY *key_info=show_table->key_info;
203
uint32_t primary_key= show_table->s->primary_key;
204
show_table->cursor->info(HA_STATUS_VARIABLE |
207
for (uint32_t i= 0; i < show_table->s->keys; i++, key_info++)
209
if (i != primary_key && ! (key_info->flags & HA_NOSAME))
214
if (i == primary_key && is_primary_key(key_info))
216
if (store_constraints(table,
220
strlen(key_info->name),
221
STRING_WITH_LEN("PRIMARY KEY"),
227
else if (key_info->flags & HA_NOSAME)
229
if (store_constraints(table,
233
strlen(key_info->name),
234
STRING_WITH_LEN("UNIQUE"),
242
show_table->cursor->get_foreign_key_list(session, &f_key_list);
243
FOREIGN_KEY_INFO *f_key_info= NULL;
244
List_iterator_fast<FOREIGN_KEY_INFO> it(f_key_list);
245
while ((f_key_info= it++))
247
if (store_constraints(table,
250
f_key_info->forein_id->str,
251
strlen(f_key_info->forein_id->str),