1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2008 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; version 2 of the License.
10
* This program is distributed in the hope that it will be useful,
11
* but WITHOUT ANY WARRANTY; without even the implied warranty of
12
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
* GNU General Public License for more details.
15
* You should have received a copy of the GNU General Public License
16
* along with this program; if not, write to the Free Software
17
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
23
Routines to drop, repair, optimize, analyze, and check a schema table
26
#ifndef DRIZZLE_SERVER_SQL_TABLE_H
27
#define DRIZZLE_SERVER_SQL_TABLE_H
31
typedef struct st_ha_check_opt HA_CHECK_OPT;
34
namespace drizzled { namespace message { class Table; } }
36
bool mysql_rm_table(Session *session,TableList *tables, bool if_exists,
38
int mysql_rm_table_part2(Session *session, TableList *tables, bool if_exists,
39
bool drop_temporary, bool log_query);
40
bool quick_rm_table(StorageEngine *, const char *db,
41
const char *table_name, bool is_tmp);
42
void close_cached_table(Session *session, Table *table);
44
void wait_while_table_is_used(Session *session, Table *table,
45
enum ha_extra_function function);
47
bool mysql_alter_table(Session *session, char *new_db, char *new_name,
48
HA_CREATE_INFO *create_info,
49
drizzled::message::Table *create_proto,
50
TableList *table_list,
51
AlterInfo *alter_info,
52
uint32_t order_num, order_st *order, bool ignore);
53
bool mysql_checksum_table(Session* session, TableList* table_list,
54
HA_CHECK_OPT* check_opt);
55
bool mysql_check_table(Session* session, TableList* table_list,
56
HA_CHECK_OPT* check_opt);
57
bool mysql_analyze_table(Session* session, TableList* table_list,
58
HA_CHECK_OPT* check_opt);
59
bool mysql_optimize_table(Session* session, TableList* table_list,
60
HA_CHECK_OPT* check_opt);
62
void write_bin_log(Session *session, bool clear_error,
63
char const *query, size_t query_length);
65
bool is_primary_key(KEY *key_info);
66
const char* is_primary_key_name(const char* key_name);
67
bool check_engine(Session *, const char *, HA_CREATE_INFO *);
68
void set_table_default_charset(HA_CREATE_INFO *create_info, char *db);
70
Preparation for table creation
73
mysql_prepare_create_table()
74
session Thread object.
75
create_info Create information (like MAX_ROWS).
76
alter_info List of columns and indexes to create
77
tmp_table If a temporary table is to be created.
78
db_options INOUT Table options (like HA_OPTION_PACK_RECORD).
79
file The handler for the new table.
80
key_info_buffer OUT An array of KEY structs for the indexes.
81
key_count OUT The number of elements in the array.
82
select_field_count The number of fields coming from a select table.
85
Prepares the table and key structures for table creation.
88
sets create_info->varchar if the table has a varchar
94
int mysql_prepare_create_table(Session *session,
95
HA_CREATE_INFO *create_info,
96
AlterInfo *alter_info,
100
KEY **key_info_buffer,
102
int select_field_count);
104
#endif /* DRIZZLE_SERVER_SQL_TABLE_H */