handler.h 18.7 KB
Newer Older
1
/* Copyright (C) 2000,2004 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
2

unknown's avatar
unknown committed
3 4 5 6
   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2 of the License, or
   (at your option) any later version.
7

unknown's avatar
unknown committed
8 9 10 11
   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.
12

unknown's avatar
unknown committed
13 14 15 16 17 18 19 20 21 22 23
   You should have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software
   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */


/* Definitions for parameters to do with handler-routines */

#ifdef __GNUC__
#pragma interface			/* gcc class implementation */
#endif

unknown's avatar
unknown committed
24
#include <ft_global.h>
unknown's avatar
unknown committed
25
#include <keycache.h>
unknown's avatar
unknown committed
26

unknown's avatar
unknown committed
27 28 29 30
#ifndef NO_HASH
#define NO_HASH				/* Not yet implemented */
#endif

unknown's avatar
unknown committed
31 32
#if defined(HAVE_BERKELEY_DB) || defined(HAVE_INNOBASE_DB) || \
    defined(HAVE_NDBCLUSTER_DB)
33 34 35
#define USING_TRANSACTIONS
#endif

unknown's avatar
unknown committed
36 37
// the following is for checking tables

38 39 40 41 42 43
#define HA_ADMIN_ALREADY_DONE	  1
#define HA_ADMIN_OK               0
#define HA_ADMIN_NOT_IMPLEMENTED -1
#define HA_ADMIN_FAILED		 -2
#define HA_ADMIN_CORRUPT         -3
#define HA_ADMIN_INTERNAL_ERROR  -4
unknown's avatar
unknown committed
44
#define HA_ADMIN_INVALID         -5
unknown's avatar
unknown committed
45
#define HA_ADMIN_REJECT          -6
unknown's avatar
unknown committed
46

47
/* Bits in table_flags() to show what database can do */
unknown's avatar
unknown committed
48 49 50 51 52 53 54
#define HA_READ_RND_SAME        1       /* Read RND-record to KEY-record
                                           (To update with RND-read)       */
#define HA_KEYPOS_TO_RNDPOS     2       /* ha_info gives pos to record */
#define HA_TABLE_SCAN_ON_INDEX  4       /* No separate data/index file */
#define HA_REC_NOT_IN_SEQ       8       /* ha_info don't return recnumber;
                                           It returns a position to ha_r_rnd */
#define HA_HAS_GEOMETRY        (1 << 4)
55
#define HA_FAST_KEY_READ       (1 << 5) /* no need for a record cache in filesort */
unknown's avatar
unknown committed
56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
#define HA_KEY_READ_WRONG_STR  (1 << 6) /* keyread returns converted strings */
#define HA_NULL_KEY            (1 << 7) /* One can have keys with NULL */
#define HA_DUPP_POS            (1 << 8) /* ha_position() gives dupp row */
#define HA_NO_BLOBS            (1 << 9) /* Doesn't support blobs */
#define HA_BLOB_KEY            (1 << 10) /* key on blob */
#define HA_AUTO_PART_KEY       (1 << 11)
#define HA_REQUIRE_PRIMARY_KEY (1 << 12)
#define HA_NOT_EXACT_COUNT     (1 << 13)
#define HA_NO_WRITE_DELAYED    (1 << 14)
#define HA_PRIMARY_KEY_IN_READ_INDEX (1 << 15)
#define HA_DROP_BEFORE_CREATE  (1 << 16)
#define HA_NOT_READ_AFTER_KEY  (1 << 17)
#define HA_NOT_DELETE_WITH_CACHE (1 << 18)
#define HA_NO_TEMP_TABLES      (1 << 19)
#define HA_NO_PREFIX_CHAR_KEYS (1 << 20)
#define HA_CAN_FULLTEXT        (1 << 21)
#define HA_CAN_SQL_HANDLER     (1 << 22)
#define HA_NO_AUTO_INCREMENT   (1 << 23)
#define HA_HAS_CHECKSUM        (1 << 24)
75 76
/*
  Next record gives next record according last record read (even
77
  if database is updated after read).  Not used at this point.
78
*/
unknown's avatar
unknown committed
79 80 81 82
#define HA_LASTKEY_ORDER       (1 << 25)
/* Table data are stored in separate files */
#define HA_FILE_BASED	       (1 << 26)

83

84 85 86 87 88 89
/* bits in index_flags(index_number) for what you can do with index */
#define HA_WRONG_ASCII_ORDER	1	/* Can't use sorting through key */
#define HA_READ_NEXT		2	/* Read next record with same key */
#define HA_READ_PREV		4	/* Read prev. record with same key */
#define HA_READ_ORDER		8	/* Read through record-keys in order */
#define HA_ONLY_WHOLE_INDEX	16	/* Can't use part key searches */
90
#define HA_NOT_READ_PREFIX_LAST	32	/* No support for index_read_last() */
91
#define HA_KEY_READ_ONLY	64	/* Support HA_EXTRA_KEYREAD */
92

93

94 95 96 97 98 99 100
/* operations for disable/enable indexes */
#define HA_KEY_SWITCH_NONUNIQ      0
#define HA_KEY_SWITCH_ALL          1
#define HA_KEY_SWITCH_NONUNIQ_SAVE 2
#define HA_KEY_SWITCH_ALL_SAVE     3


101
/*
102 103 104 105
  Bits in index_ddl_flags(KEY *wanted_index)
  for what ddl you can do with index
  If none is set, the wanted type of index is not supported
  by the handler at all. See WorkLog 1563.
106 107 108 109 110 111 112 113
*/
#define HA_DDL_SUPPORT   1 /* Supported by handler */
#define HA_DDL_WITH_LOCK 2 /* Can create/drop with locked table */
#define HA_DDL_ONLINE    4 /* Can create/drop without lock */

/* Return value for ddl methods */
#define HA_DDL_NOT_IMPLEMENTED -1

114 115 116 117
/*
  Parameters for open() (in register form->filestat)
  HA_GET_INFO does an implicit HA_ABORT_IF_LOCKED
*/
unknown's avatar
unknown committed
118 119 120 121 122 123

#define HA_OPEN_KEYFILE		1
#define HA_OPEN_RNDFILE		2
#define HA_GET_INDEX		4
#define HA_GET_INFO		8	/* do a ha_info() after open */
#define HA_READ_ONLY		16	/* File opened as readonly */
124 125
/* Try readonly if can't open with read and write */
#define HA_TRY_READ_ONLY	32
unknown's avatar
unknown committed
126 127 128 129 130
#define HA_WAIT_IF_LOCKED	64	/* Wait if locked on open */
#define HA_ABORT_IF_LOCKED	128	/* skip if locked on open.*/
#define HA_BLOCK_LOCK		256	/* unlock when reading some records */
#define HA_OPEN_TEMPORARY	512

131
	/* Errors on write which is recoverable  (Key exist) */
unknown's avatar
unknown committed
132
#define HA_WRITE_SKIP 121		/* Duplicate key on write */
unknown's avatar
unknown committed
133 134 135 136 137 138 139 140 141 142 143 144 145
#define HA_READ_CHECK 123		/* Update with is recoverable */
#define HA_CANT_DO_THAT 131		/* Databasehandler can't do it */

	/* Some key definitions */
#define HA_KEY_NULL_LENGTH	1
#define HA_KEY_BLOB_LENGTH	2

#define HA_LEX_CREATE_TMP_TABLE	1
#define HA_LEX_CREATE_IF_NOT_EXISTS 2
#define HA_OPTION_NO_CHECKSUM	(1L << 17)
#define HA_OPTION_NO_DELAY_KEY_WRITE (1L << 18)
#define HA_MAX_REC_LENGTH	65535

146 147
/* Table caching type */
#define HA_CACHE_TBL_NONTRANSACT 0
148 149 150 151
#define HA_CACHE_TBL_NOCACHE     1
#define HA_CACHE_TBL_ASKTRANSACT 2
#define HA_CACHE_TBL_TRANSACT    4

152

unknown's avatar
unknown committed
153 154 155 156 157 158 159 160
enum db_type 
{ 
  DB_TYPE_UNKNOWN=0,DB_TYPE_DIAB_ISAM=1,
  DB_TYPE_HASH,DB_TYPE_MISAM,DB_TYPE_PISAM,
  DB_TYPE_RMS_ISAM, DB_TYPE_HEAP, DB_TYPE_ISAM,
  DB_TYPE_MRG_ISAM, DB_TYPE_MYISAM, DB_TYPE_MRG_MYISAM,
  DB_TYPE_BERKELEY_DB, DB_TYPE_INNODB, 
  DB_TYPE_GEMINI, DB_TYPE_NDBCLUSTER,
161
  DB_TYPE_EXAMPLE_DB, DB_TYPE_ARCHIVE_DB,
unknown's avatar
unknown committed
162 163 164
	       
  DB_TYPE_DEFAULT // Must be last
};
unknown's avatar
unknown committed
165

166 167 168 169 170 171 172
struct show_table_type_st {
  const char *type;
  SHOW_COMP_OPTION *value;
  const char *comment;
  enum db_type db_type;
};

173 174
enum row_type { ROW_TYPE_NOT_USED=-1, ROW_TYPE_DEFAULT, ROW_TYPE_FIXED,
		ROW_TYPE_DYNAMIC, ROW_TYPE_COMPRESSED};
unknown's avatar
unknown committed
175 176 177 178

/* struct to hold information about the table that should be created */

/* Bits in used_fields */
179 180 181 182
#define HA_CREATE_USED_AUTO		1
#define HA_CREATE_USED_RAID		2
#define HA_CREATE_USED_UNION		4
#define HA_CREATE_USED_INSERT_METHOD	8
183 184 185 186
#define HA_CREATE_USED_MIN_ROWS		16
#define HA_CREATE_USED_MAX_ROWS		32
#define HA_CREATE_USED_AVG_ROW_LENGTH	64
#define HA_CREATE_USED_PACK_KEYS	128
187
#define HA_CREATE_USED_CHARSET		256
188
#define HA_CREATE_USED_DEFAULT_CHARSET	512
unknown's avatar
unknown committed
189

190 191 192
typedef struct st_thd_trans {
  void *bdb_tid;
  void *innobase_tid;
unknown's avatar
unknown committed
193
  bool innodb_active_trans;
unknown's avatar
unknown committed
194
  void *ndb_tid;
195 196
} THD_TRANS;

unknown's avatar
unknown committed
197 198 199
enum enum_tx_isolation { ISO_READ_UNCOMMITTED, ISO_READ_COMMITTED,
			 ISO_REPEATABLE_READ, ISO_SERIALIZABLE};

unknown's avatar
unknown committed
200 201
typedef struct st_ha_create_information
{
202
  CHARSET_INFO *table_charset, *default_table_charset;
unknown's avatar
unknown committed
203 204 205
  const char *comment,*password;
  const char *data_file_name, *index_file_name;
  const char *alias;
206 207 208 209
  ulonglong max_rows,min_rows;
  ulonglong auto_increment_value;
  ulong table_options;
  ulong avg_row_length;
unknown's avatar
unknown committed
210 211
  ulong raid_chunksize;
  ulong used_fields;
212
  SQL_LIST merge_list;
213 214
  enum db_type db_type;
  enum row_type row_type;
215
  uint options;				/* OR of HA_CREATE_ options */
216
  uint raid_type,raid_chunks;
217
  uint merge_insert_method;
218
  bool table_existed;			/* 1 in create if table existed */
unknown's avatar
unknown committed
219 220 221 222 223 224 225 226 227 228 229
} HA_CREATE_INFO;


/* The handler for a table type.  Will be included in the TABLE structure */

struct st_table;
typedef struct st_table TABLE;

typedef struct st_ha_check_opt
{
  ulong sort_buffer_size;
unknown's avatar
unknown committed
230 231
  uint flags;       /* isam layer flags (e.g. for myisamchk) */
  uint sql_flags;   /* sql layer flags - for something myisamchk cannot do */
unknown's avatar
unknown committed
232
  KEY_CACHE *key_cache;	/* new key cache when changing key cache */
unknown's avatar
unknown committed
233
  void init();
unknown's avatar
unknown committed
234 235
} HA_CHECK_OPT;

236

unknown's avatar
unknown committed
237 238 239 240 241 242 243 244 245 246 247 248 249 250
class handler :public Sql_alloc
{
 protected:
  struct st_table *table;		/* The table definition */

public:
  byte *ref;				/* Pointer to current row */
  byte *dupp_ref;			/* Pointer to dupp row */
  ulonglong data_file_length;		/* Length off data file */
  ulonglong max_data_file_length;	/* Length off data file */
  ulonglong index_file_length;
  ulonglong max_index_file_length;
  ulonglong delete_length;		/* Free bytes */
  ulonglong auto_increment_value;
251 252
  ha_rows records;			/* Records in table */
  ha_rows deleted;			/* Deleted records */
unknown's avatar
unknown committed
253
  ulong raid_chunksize;
254
  ulong mean_rec_length;		/* physical reclength */
unknown's avatar
unknown committed
255 256 257
  time_t create_time;			/* When table was created */
  time_t check_time;
  time_t update_time;
258 259 260 261 262

  /* The following are for read_range() */
  key_range save_end_range, *end_range;
  KEY_PART_INFO *range_key_part;
  int key_compare_result_on_equal;
unknown's avatar
unknown committed
263
  bool eq_range;
264

265 266 267 268 269 270 271
  uint errkey;				/* Last dup key */
  uint sortkey, key_used_on_scan;
  uint active_index;
  /* Length of ref (1-8 or the clustered key length) */
  uint ref_length;
  uint block_size;			/* index block size */
  uint raid_type,raid_chunks;
unknown's avatar
unknown committed
272
  FT_INFO *ft_handler;
273
  bool  auto_increment_column_changed;
274
  bool implicit_emptied;                /* Can be !=0 only if HEAP */
unknown's avatar
unknown committed
275

276

277 278 279 280 281 282 283
  handler(TABLE *table_arg) :table(table_arg),
    ref(0), data_file_length(0), max_data_file_length(0), index_file_length(0),
    delete_length(0), auto_increment_value(0),
    records(0), deleted(0), mean_rec_length(0),
    create_time(0), check_time(0), update_time(0),
    key_used_on_scan(MAX_KEY), active_index(MAX_REF_PARTS),
    ref_length(sizeof(my_off_t)), block_size(0),
284
    raid_type(0), ft_handler(0), implicit_emptied(0)
unknown's avatar
unknown committed
285
    {}
unknown's avatar
unknown committed
286
  virtual ~handler(void) {}
unknown's avatar
unknown committed
287 288 289
  int ha_open(const char *name, int mode, int test_if_locked);
  void update_timestamp(byte *record);
  void update_auto_increment();
unknown's avatar
unknown committed
290
  virtual void print_error(int error, myf errflag);
291
  virtual bool get_error_message(int error, String *buf);
unknown's avatar
unknown committed
292 293 294
  uint get_dup_key(int error);
  void change_table_ptr(TABLE *table_arg) { table=table_arg; }
  virtual double scan_time()
295
    { return ulonglong2double(data_file_length) / IO_SIZE + 2; }
unknown's avatar
unknown committed
296 297
  virtual double read_time(uint index, uint ranges, ha_rows rows)
 { return rows2double(ranges+rows); }
unknown's avatar
unknown committed
298
  virtual const key_map *keys_to_use_for_scanning() { return &key_map_empty; }
unknown's avatar
unknown committed
299
  virtual bool has_transactions(){ return 0;}
300
  virtual uint extra_rec_buf_length() { return 0; }
301
  virtual ha_rows estimate_number_of_rows() { return records+EXTRA_RECORDS; }
302
  virtual const char *index_type(uint key_number) { return "";}
unknown's avatar
unknown committed
303 304 305 306

  virtual int index_init(uint idx) { active_index=idx; return 0;}
  virtual int index_end() {return 0; }
  uint get_index(void) const { return active_index; }
307
  virtual int open(const char *name, int mode, uint test_if_locked)=0;
unknown's avatar
unknown committed
308 309 310 311 312 313
  virtual void initialize(void) {}
  virtual int close(void)=0;
  virtual int write_row(byte * buf)=0;
  virtual int update_row(const byte * old_data, byte * new_data)=0;
  virtual int delete_row(const byte * buf)=0;
  virtual int index_read(byte * buf, const byte * key,
314
			 uint key_len, enum ha_rkey_function find_flag)=0;
unknown's avatar
unknown committed
315 316 317 318 319 320 321
  virtual int index_read_idx(byte * buf, uint index, const byte * key,
			     uint key_len, enum ha_rkey_function find_flag)=0;
  virtual int index_next(byte * buf)=0;
  virtual int index_prev(byte * buf)=0;
  virtual int index_first(byte * buf)=0;
  virtual int index_last(byte * buf)=0;
  virtual int index_next_same(byte *buf, const byte *key, uint keylen);
322 323 324 325
  virtual int index_read_last(byte * buf, const byte * key, uint key_len)
  {
    return (my_errno=HA_ERR_WRONG_COMMAND);
  }
326
  virtual int read_range_first(const key_range *start_key,
unknown's avatar
unknown committed
327 328 329
                               const key_range *end_key,
                               bool eq_range, bool sorted);
  virtual int read_range_next();
330
  int compare_key(key_range *range);
331
  virtual int ft_init()
332
    { return -1; }
unknown's avatar
unknown committed
333 334
  virtual FT_INFO *ft_init_ext(uint flags,uint inx,const byte *key,
                               uint keylen)
unknown's avatar
unknown committed
335
    { return NULL; }
unknown's avatar
unknown committed
336 337 338 339 340
  virtual int ft_read(byte *buf) { return -1; }
  virtual int rnd_init(bool scan=1)=0;
  virtual int rnd_end() { return 0; }
  virtual int rnd_next(byte *buf)=0;
  virtual int rnd_pos(byte * buf, byte *pos)=0;
341
  virtual int read_first_row(byte *buf, uint primary_key);
unknown's avatar
unknown committed
342
  virtual int restart_rnd_next(byte *buf, byte *pos);
unknown's avatar
unknown committed
343 344
  virtual ha_rows records_in_range(uint inx, key_range *min_key,
                                   key_range *max_key)
unknown's avatar
unknown committed
345 346 347 348 349
    { return (ha_rows) 10; }
  virtual void position(const byte *record)=0;
  virtual my_off_t row_position() { return HA_OFFSET_ERROR; }
  virtual void info(uint)=0;
  virtual int extra(enum ha_extra_function operation)=0;
unknown's avatar
unknown committed
350 351 352 353
  virtual int extra_opt(enum ha_extra_function operation, ulong cache_size)
  {
    return extra(operation);
  }
354
  virtual int reset() { return extra(HA_EXTRA_RESET); }
unknown's avatar
unknown committed
355
  virtual int external_lock(THD *thd, int lock_type)=0;
unknown's avatar
unknown committed
356
  virtual void unlock_row() {}
unknown's avatar
unknown committed
357
  virtual int start_stmt(THD *thd) {return 0;}
unknown's avatar
unknown committed
358 359 360
  virtual int delete_all_rows();
  virtual longlong get_auto_increment();
  virtual void update_create_info(HA_CREATE_INFO *create_info) {}
361 362
  virtual int check(THD* thd,   HA_CHECK_OPT* check_opt );
  virtual int repair(THD* thd,  HA_CHECK_OPT* check_opt);
363
  virtual bool check_and_repair(THD *thd) {return 1;}
364 365
  virtual int optimize(THD* thd,HA_CHECK_OPT* check_opt);
  virtual int analyze(THD* thd, HA_CHECK_OPT* check_opt);
366
  virtual int assign_to_keycache(THD* thd, HA_CHECK_OPT* check_opt);
unknown's avatar
unknown committed
367
  virtual int preload_keys(THD* thd, HA_CHECK_OPT* check_opt);
unknown's avatar
unknown committed
368
  virtual int backup(THD* thd, HA_CHECK_OPT* check_opt);
369 370 371 372
  /*
    restore assumes .frm file must exist, and that generate_table() has been
    called; It will just copy the data file and run repair.
  */
unknown's avatar
unknown committed
373
  virtual int restore(THD* thd, HA_CHECK_OPT* check_opt);
unknown's avatar
unknown committed
374
  virtual int dump(THD* thd, int fd = -1) { return ER_DUMP_NOT_IMPLEMENTED; }
375 376 377
  virtual int disable_indexes(uint mode) { return HA_ERR_WRONG_COMMAND; }
  virtual int enable_indexes(uint mode) { return HA_ERR_WRONG_COMMAND; }
  virtual int indexes_are_disabled(void) {return 0;}
378 379
  virtual void start_bulk_insert(ha_rows rows) {}
  virtual int end_bulk_insert() {return 0; }
unknown's avatar
unknown committed
380
  virtual int discard_or_import_tablespace(my_bool discard) {return -1;}
unknown's avatar
unknown committed
381 382 383
  // not implemented by default
  virtual int net_read_dump(NET* net)
  { return ER_DUMP_NOT_IMPLEMENTED; }
384 385 386
  virtual char *update_table_comment(const char * comment)
  { return (char*) comment;}
  virtual void append_create_info(String *packet) {}
387 388
  virtual char* get_foreign_key_create_info()
  { return(NULL);}  /* gets foreign key create string from InnoDB */
unknown's avatar
unknown committed
389 390
  /* used in REPLACE; is > 0 if table is referred by a FOREIGN KEY */
  virtual uint referenced_by_foreign_key() { return 0;}
unknown's avatar
unknown committed
391
  virtual void init_table_handle_for_HANDLER()
unknown's avatar
unknown committed
392 393
  { return; }       /* prepare InnoDB for HANDLER */
  virtual void free_foreign_key_create_info(char* str) {}
unknown's avatar
unknown committed
394 395 396
  /* The following can be called without an open handler */
  virtual const char *table_type() const =0;
  virtual const char **bas_ext() const =0;
397 398 399
  virtual ulong table_flags(void) const =0;
  virtual ulong index_flags(uint idx) const
  {
400
    return (HA_READ_NEXT | HA_READ_PREV | HA_READ_ORDER | HA_KEY_READ_ONLY);
401
  }
402 403 404 405
  virtual ulong index_ddl_flags(KEY *wanted_index) const
  {
    return (HA_DDL_SUPPORT);
  }
406
  virtual int add_index(TABLE *table_arg, KEY *key_info, uint num_of_keys)
407 408 409 410
  {
    my_error(ER_NOT_SUPPORTED_YET, MYF(0), "online add index");
    return (HA_DDL_NOT_IMPLEMENTED);
  }
411
  virtual int drop_index(TABLE *table_arg, uint *key_num, uint num_of_keys)
412 413 414 415
  {
    my_error(ER_NOT_SUPPORTED_YET, MYF(0), "online drop index");
    return (HA_DDL_NOT_IMPLEMENTED);
  }
unknown's avatar
unknown committed
416 417 418 419
  virtual uint max_record_length() const =0;
  virtual uint max_keys() const =0;
  virtual uint max_key_parts() const =0;
  virtual uint max_key_length()const =0;
420
  virtual uint max_key_part_length() { return 255; }
unknown's avatar
unknown committed
421 422
  virtual uint min_record_length(uint options) const { return 1; }
  virtual bool low_byte_first() const { return 1; }
unknown's avatar
unknown committed
423
  virtual uint checksum() const { return 0; }
424 425
  virtual bool is_crashed() const  { return 0; }
  virtual bool auto_repair() const { return 0; }
unknown's avatar
unknown committed
426 427 428 429 430 431 432 433

  virtual int rename_table(const char *from, const char *to);
  virtual int delete_table(const char *name);
  virtual int create(const char *name, TABLE *form, HA_CREATE_INFO *info)=0;
  virtual uint lock_count(void) const { return 1; }
  virtual THR_LOCK_DATA **store_lock(THD *thd,
				     THR_LOCK_DATA **to,
				     enum thr_lock_type lock_type)=0;
434 435 436

  /* Type of table for caching query */
  virtual uint8 table_cache_type() { return HA_CACHE_TBL_NONTRANSACT; }
unknown's avatar
unknown committed
437 438
  /*
    Is query with this table cachable (have sense only for ASKTRANSACT
439 440
    tables)
  */
unknown's avatar
unknown committed
441
  static bool caching_allowed(THD* thd, char* table_key,
442
			      uint key_length, uint8 cahe_type);
unknown's avatar
unknown committed
443 444 445 446
};

	/* Some extern variables used with handlers */

447
extern struct show_table_type_st sys_table_types[];
unknown's avatar
unknown committed
448
extern const char *ha_row_type[];
449
extern TYPELIB tx_isolation_typelib;
unknown's avatar
unknown committed
450

451 452 453 454 455 456
	/* Wrapper functions */
#define ha_commit_stmt(thd) (ha_commit_trans((thd), &((thd)->transaction.stmt)))
#define ha_rollback_stmt(thd) (ha_rollback_trans((thd), &((thd)->transaction.stmt)))
#define ha_commit(thd) (ha_commit_trans((thd), &((thd)->transaction.all)))
#define ha_rollback(thd) (ha_rollback_trans((thd), &((thd)->transaction.all)))

457 458
#define ha_supports_generate(T) (T != DB_TYPE_INNODB)

459
enum db_type ha_resolve_by_name(const char *name, uint namelen);
unknown's avatar
unknown committed
460
const char *ha_get_storage_engine(enum db_type db_type);
unknown's avatar
unknown committed
461 462 463 464 465
handler *get_new_handler(TABLE *table, enum db_type db_type);
my_off_t ha_get_ptr(byte *ptr, uint pack_length);
void ha_store_ptr(byte *buff, uint pack_length, my_off_t pos);
int ha_init(void);
int ha_panic(enum ha_panic_function flag);
466
void ha_close_connection(THD* thd);
unknown's avatar
unknown committed
467 468 469 470
enum db_type ha_checktype(enum db_type database_type);
int ha_create_table(const char *name, HA_CREATE_INFO *create_info,
		    bool update_create_info);
int ha_delete_table(enum db_type db_type, const char *path);
471
void ha_drop_database(char* path);
unknown's avatar
unknown committed
472 473 474 475
int ha_init_key_cache(const char *name, KEY_CACHE *key_cache);
int ha_resize_key_cache(KEY_CACHE *key_cache);
int ha_change_key_cache_param(KEY_CACHE *key_cache);
int ha_end_key_cache(KEY_CACHE *key_cache);
unknown's avatar
unknown committed
476
int ha_start_stmt(THD *thd);
477 478
int ha_report_binlog_offset_and_commit(THD *thd, char *log_file_name,
				       my_off_t end_offset);
unknown's avatar
unknown committed
479
int ha_commit_complete(THD *thd);
480
int ha_release_temporary_latches(THD *thd);
481 482
int ha_commit_trans(THD *thd, THD_TRANS *trans);
int ha_rollback_trans(THD *thd, THD_TRANS *trans);
unknown's avatar
unknown committed
483 484
int ha_rollback_to_savepoint(THD *thd, char *savepoint_name);
int ha_savepoint(THD *thd, char *savepoint_name);
unknown's avatar
unknown committed
485
int ha_autocommit_or_rollback(THD *thd, int error);
unknown's avatar
unknown committed
486
void ha_set_spin_retries(uint retries);
unknown's avatar
unknown committed
487
bool ha_flush_logs(void);
488
int ha_recovery_logging(THD *thd, bool on);
unknown's avatar
unknown committed
489 490
int ha_change_key_cache(KEY_CACHE *old_key_cache,
			KEY_CACHE *new_key_cache);
unknown's avatar
unknown committed
491 492
int ha_discover(const char* dbname, const char* name,
		const void** frmblob, uint* frmlen);