29
29
#include "drizzled/base.h"
36
33
typedef struct st_ha_check_opt HA_CHECK_OPT;
35
typedef struct st_key KEY;
38
36
typedef struct st_ha_create_information HA_CREATE_INFO;
42
namespace message { class Table; }
43
namespace identifier { class Table; }
45
int rm_table_part2(Session *session, TableList *tables, bool if_exists,
40
/* Flags for conversion functions. */
41
static const uint32_t FN_FROM_IS_TMP(1 << 0);
42
static const uint32_t FN_TO_IS_TMP(1 << 0);
44
namespace drizzled { namespace message { class Table; } }
45
namespace drizzled { class TableIdentifier; }
47
int mysql_rm_table_part2(Session *session, TableList *tables, bool if_exists,
46
48
bool drop_temporary);
49
void write_bin_log_drop_table(Session *session,
50
bool if_exists, const char *db_name,
51
const char *table_name);
52
bool quick_rm_table(Session& session,
53
drizzled::TableIdentifier &identifier);
47
54
void close_cached_table(Session *session, Table *table);
49
56
void wait_while_table_is_used(Session *session, Table *table,
50
57
enum ha_extra_function function);
52
bool check_table(Session* session, TableList* table_list,
53
HA_CHECK_OPT* check_opt);
54
bool analyze_table(Session* session, TableList* table_list,
55
HA_CHECK_OPT* check_opt);
56
bool optimize_table(Session* session, TableList* table_list,
57
HA_CHECK_OPT* check_opt);
59
void write_bin_log(Session *session, const std::string &query);
61
bool is_primary_key(KeyInfo *key_info);
59
bool mysql_checksum_table(Session* session, TableList* table_list,
60
HA_CHECK_OPT* check_opt);
61
bool mysql_check_table(Session* session, TableList* table_list,
62
HA_CHECK_OPT* check_opt);
63
bool mysql_analyze_table(Session* session, TableList* table_list,
64
HA_CHECK_OPT* check_opt);
65
bool mysql_optimize_table(Session* session, TableList* table_list,
66
HA_CHECK_OPT* check_opt);
68
void write_bin_log(Session *session,
69
char const *query, size_t query_length);
71
bool is_primary_key(KEY *key_info);
62
72
const char* is_primary_key_name(const char* key_name);
63
bool check_engine(Session *, const char *, message::Table *, HA_CREATE_INFO *);
73
bool check_engine(Session *, const char *, drizzled::message::Table *, HA_CREATE_INFO *);
64
74
void set_table_default_charset(HA_CREATE_INFO *create_info, const char *db);
65
} /* namespace drizzled */
76
Preparation for table creation
79
mysql_prepare_create_table()
80
session Thread object.
81
create_info Create information (like MAX_ROWS).
82
alter_info List of columns and indexes to create
83
tmp_table If a temporary table is to be created.
84
db_options INOUT Table options (like HA_OPTION_PACK_RECORD).
85
file The Cursor for the new table.
86
key_info_buffer OUT An array of KEY structs for the indexes.
87
key_count OUT The number of elements in the array.
88
select_field_count The number of fields coming from a select table.
91
Prepares the table and key structures for table creation.
94
sets create_info->varchar if the table has a varchar
100
int mysql_prepare_create_table(Session *session,
101
HA_CREATE_INFO *create_info,
102
drizzled::message::Table *create_proto,
103
AlterInfo *alter_info,
105
uint32_t *db_options,
107
KEY **key_info_buffer,
109
int select_field_count);
112
/* Conversion functions */
113
size_t build_tmptable_filename(char *buff, size_t bufflen);
114
size_t build_table_filename(char *buff, size_t bufflen, const char *db,
115
const char *table_name, bool is_tmp);
67
117
#endif /* DRIZZLED_SQL_TABLE_H */