390.1.2
by Monty Taylor
Fixed copyright headers in drizzled/ |
1 |
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
|
2 |
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
|
|
3 |
*
|
|
4 |
* Copyright (C) 2008 Sun Microsystems
|
|
5 |
*
|
|
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.
|
|
9 |
*
|
|
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.
|
|
14 |
*
|
|
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
|
|
18 |
*/
|
|
1
by brian
clean slate |
19 |
|
520.6.4
by Monty Taylor
Moved thr_lock.h out of common_includes. |
20 |
#ifndef DRIZZLED_HANDLER_H
|
21 |
#define DRIZZLED_HANDLER_H
|
|
1
by brian
clean slate |
22 |
|
520.4.31
by Monty Taylor
Removed server_id from common_includes. |
23 |
#include <drizzled/xid.h> |
24 |
||
1
by brian
clean slate |
25 |
/* Definitions for parameters to do with handler-routines */
|
26 |
||
212.4.2
by Monty Taylor
Fixed the includes in places to make the myisam header file move work. |
27 |
#include <storage/myisam/keycache.h> |
520.6.4
by Monty Taylor
Moved thr_lock.h out of common_includes. |
28 |
#include <mysys/thr_lock.h> |
520.8.3
by Monty Taylor
Moved hash back to mysys. |
29 |
#include <mysys/hash.h> |
520.8.5
by Monty Taylor
Removed sql_string and sql_list from common_includes. |
30 |
#include <drizzled/sql_string.h> |
31 |
#include <drizzled/sql_list.h> |
|
575.1.3
by Monty Taylor
Moved some stuff out of handler.h. |
32 |
#include <drizzled/handlerton.h> |
33 |
#include <drizzled/handler_structs.h> |
|
34 |
#include <drizzled/ha_statistics.h> |
|
520.6.4
by Monty Taylor
Moved thr_lock.h out of common_includes. |
35 |
|
36 |
/* Bits to show what an alter table will do */
|
|
37 |
#include <drizzled/sql_bitmap.h> |
|
38 |
||
39 |
#define HA_MAX_ALTER_FLAGS 40
|
|
40 |
typedef Bitmap<HA_MAX_ALTER_FLAGS> HA_ALTER_FLAGS; |
|
1
by brian
clean slate |
41 |
|
42 |
||
520.1.22
by Brian Aker
Second pass of thd cleanup |
43 |
typedef bool (*qc_engine_callback)(Session *session, char *table_key, |
482
by Brian Aker
Remove uint. |
44 |
uint32_t key_length, |
243.1.1
by Jay Pipes
* Pulled Object_creation_ctx and Default_creation_ctx out of mysql_priv.h |
45 |
uint64_t *engine_data); |
46 |
||
1
by brian
clean slate |
47 |
|
327.1.5
by Brian Aker
Refactor around classes. TABLE_LIST has been factored out of table.h |
48 |
/* The handler for a table type. Will be included in the Table structure */
|
1
by brian
clean slate |
49 |
|
327.1.1
by Brian Aker
First pass in encapsulating table (it is now an object, no longer a structure). |
50 |
class Table; |
561.1.3
by Monty Taylor
Split some more things out of common_includes.h. |
51 |
class TableList; |
1
by brian
clean slate |
52 |
typedef struct st_table_share TABLE_SHARE; |
53 |
struct st_foreign_key_info; |
|
54 |
typedef struct st_foreign_key_info FOREIGN_KEY_INFO; |
|
584.1.13
by Monty Taylor
Split out a little more code. Removed table_list.h from common_includes. |
55 |
struct order_st; |
1
by brian
clean slate |
56 |
|
57 |
class Item; |
|
58 |
struct st_table_log_memory_entry; |
|
59 |
||
575.4.7
by Monty Taylor
More header cleanup. |
60 |
class LEX; |
61 |
typedef class st_select_lex SELECT_LEX; |
|
62 |
typedef class st_select_lex_unit SELECT_LEX_UNIT; |
|
63 |
class Alter_info; |
|
64 |
class select_result; |
|
65 |
class Create_field; |
|
66 |
class sys_var_str; |
|
67 |
class Item_ident; |
|
68 |
typedef struct st_sort_field SORT_FIELD; |
|
69 |
||
70 |
typedef List<Item> List_item; |
|
71 |
||
1
by brian
clean slate |
72 |
typedef struct st_savepoint SAVEPOINT; |
61
by Brian Aker
Conversion of handler type. |
73 |
extern uint32_t savepoint_alloc_size; |
1
by brian
clean slate |
74 |
extern KEY_CREATE_INFO default_key_create_info; |
75 |
||
76 |
/* Forward declaration for condition pushdown to storage engine */
|
|
77 |
typedef class Item COND; |
|
78 |
||
79 |
typedef struct system_status_var SSV; |
|
80 |
||
575.1.3
by Monty Taylor
Moved some stuff out of handler.h. |
81 |
class COST_VECT; |
82 |
||
482
by Brian Aker
Remove uint. |
83 |
uint16_t &mrr_persistent_flag_storage(range_seq_t seq, uint32_t idx); |
84 |
char* &mrr_get_ptr_by_idx(range_seq_t seq, uint32_t idx); |
|
1
by brian
clean slate |
85 |
|
482
by Brian Aker
Remove uint. |
86 |
uint32_t calculate_key_len(Table *, uint, const unsigned char *, key_part_map); |
1
by brian
clean slate |
87 |
/*
|
88 |
bitmap with first N+1 bits set
|
|
89 |
(keypart_map for a key prefix of [0..N] keyparts)
|
|
90 |
*/
|
|
575.1.3
by Monty Taylor
Moved some stuff out of handler.h. |
91 |
template<class T> |
92 |
inline key_part_map make_keypart_map(T a) |
|
93 |
{
|
|
94 |
return (((key_part_map)2 << a) - 1); |
|
95 |
}
|
|
96 |
||
1
by brian
clean slate |
97 |
/*
|
98 |
bitmap with first N bits set
|
|
99 |
(keypart_map for a key prefix of [0..N-1] keyparts)
|
|
100 |
*/
|
|
575.1.3
by Monty Taylor
Moved some stuff out of handler.h. |
101 |
template<class T> |
102 |
inline key_part_map make_prev_keypart_map(T a) |
|
103 |
{
|
|
104 |
return (((key_part_map)1 << a) - 1); |
|
105 |
}
|
|
1
by brian
clean slate |
106 |
|
107 |
/**
|
|
108 |
The handler class is the interface for dynamically loadable
|
|
109 |
storage engines. Do not add ifdefs and take care when adding or
|
|
110 |
changing virtual functions to avoid vtable confusion
|
|
111 |
||
112 |
Functions in this class accept and return table columns data. Two data
|
|
113 |
representation formats are used:
|
|
114 |
1. TableRecordFormat - Used to pass [partial] table records to/from
|
|
115 |
storage engine
|
|
116 |
||
117 |
2. KeyTupleFormat - used to pass index search tuples (aka "keys") to
|
|
118 |
storage engine. See opt_range.cc for description of this format.
|
|
119 |
||
120 |
TableRecordFormat
|
|
121 |
=================
|
|
122 |
[Warning: this description is work in progress and may be incomplete]
|
|
123 |
The table record is stored in a fixed-size buffer:
|
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
124 |
|
1
by brian
clean slate |
125 |
record: null_bytes, column1_data, column2_data, ...
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
126 |
|
127 |
The offsets of the parts of the buffer are also fixed: every column has
|
|
1
by brian
clean slate |
128 |
an offset to its column{i}_data, and if it is nullable it also has its own
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
129 |
bit in null_bytes.
|
1
by brian
clean slate |
130 |
|
131 |
The record buffer only includes data about columns that are marked in the
|
|
132 |
relevant column set (table->read_set and/or table->write_set, depending on
|
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
133 |
the situation).
|
1
by brian
clean slate |
134 |
<not-sure>It could be that it is required that null bits of non-present
|
135 |
columns are set to 1</not-sure>
|
|
136 |
||
137 |
VARIOUS EXCEPTIONS AND SPECIAL CASES
|
|
138 |
||
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
139 |
f the table has no nullable columns, then null_bytes is still
|
140 |
present, its length is one byte <not-sure> which must be set to 0xFF
|
|
1
by brian
clean slate |
141 |
at all times. </not-sure>
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
142 |
|
1
by brian
clean slate |
143 |
If the table has columns of type BIT, then certain bits from those columns
|
144 |
may be stored in null_bytes as well. Grep around for Field_bit for
|
|
145 |
details.
|
|
146 |
||
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
147 |
For blob columns (see Field_blob), the record buffer stores length of the
|
148 |
data, following by memory pointer to the blob data. The pointer is owned
|
|
1
by brian
clean slate |
149 |
by the storage engine and is valid until the next operation.
|
150 |
||
151 |
If a blob column has NULL value, then its length and blob data pointer
|
|
152 |
must be set to 0.
|
|
153 |
*/
|
|
154 |
||
155 |
class handler :public Sql_alloc |
|
156 |
{
|
|
157 |
public: |
|
158 |
typedef uint64_t Table_flags; |
|
159 |
protected: |
|
160 |
struct st_table_share *table_share; /* The table definition */ |
|
327.1.1
by Brian Aker
First pass in encapsulating table (it is now an object, no longer a structure). |
161 |
Table *table; /* The current open table */ |
1
by brian
clean slate |
162 |
Table_flags cached_table_flags; /* Set on init() and open() */ |
163 |
||
164 |
ha_rows estimation_rows_to_insert; |
|
165 |
public: |
|
166 |
handlerton *ht; /* storage engine of this handler */ |
|
481
by Brian Aker
Remove all of uchar. |
167 |
unsigned char *ref; /* Pointer to current row */ |
168 |
unsigned char *dup_ref; /* Pointer to duplicate row */ |
|
1
by brian
clean slate |
169 |
|
170 |
ha_statistics stats; |
|
171 |
/** MultiRangeRead-related members: */
|
|
172 |
range_seq_t mrr_iter; /* Interator to traverse the range sequence */ |
|
173 |
RANGE_SEQ_IF mrr_funcs; /* Range sequence traversal functions */ |
|
174 |
HANDLER_BUFFER *multi_range_buffer; /* MRR buffer info */ |
|
482
by Brian Aker
Remove uint. |
175 |
uint32_t ranges_in_seq; /* Total number of ranges in the traversed sequence */ |
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
176 |
/* true <=> source MRR ranges and the output are ordered */
|
1
by brian
clean slate |
177 |
bool mrr_is_output_sorted; |
178 |
||
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
179 |
/** true <=> we're currently traversing a range in mrr_cur_range. */
|
1
by brian
clean slate |
180 |
bool mrr_have_range; |
181 |
/** Current range (the one we're now returning rows from) */
|
|
182 |
KEY_MULTI_RANGE mrr_cur_range; |
|
183 |
||
184 |
/** The following are for read_range() */
|
|
185 |
key_range save_end_range, *end_range; |
|
186 |
KEY_PART_INFO *range_key_part; |
|
187 |
int key_compare_result_on_equal; |
|
188 |
bool eq_range; |
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
189 |
/*
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
190 |
true <=> the engine guarantees that returned records are within the range
|
1
by brian
clean slate |
191 |
being scanned.
|
192 |
*/
|
|
193 |
bool in_range_check_pushed_down; |
|
194 |
||
482
by Brian Aker
Remove uint. |
195 |
uint32_t errkey; /* Last dup key */ |
196 |
uint32_t key_used_on_scan; |
|
197 |
uint32_t active_index; |
|
1
by brian
clean slate |
198 |
/** Length of ref (1-8 or the clustered key length) */
|
482
by Brian Aker
Remove uint. |
199 |
uint32_t ref_length; |
1
by brian
clean slate |
200 |
enum {NONE=0, INDEX, RND} inited; |
201 |
bool locked; |
|
202 |
bool implicit_emptied; /* Can be !=0 only if HEAP */ |
|
203 |
const Item *pushed_cond; |
|
204 |
||
205 |
Item *pushed_idx_cond; |
|
482
by Brian Aker
Remove uint. |
206 |
uint32_t pushed_idx_cond_keyno; /* The index which the above condition is for */ |
1
by brian
clean slate |
207 |
|
208 |
/**
|
|
209 |
next_insert_id is the next value which should be inserted into the
|
|
210 |
auto_increment column: in a inserting-multi-row statement (like INSERT
|
|
211 |
SELECT), for the first row where the autoinc value is not specified by the
|
|
212 |
statement, get_auto_increment() called and asked to generate a value,
|
|
213 |
next_insert_id is set to the next value, then for all other rows
|
|
214 |
next_insert_id is used (and increased each time) without calling
|
|
215 |
get_auto_increment().
|
|
216 |
*/
|
|
217 |
uint64_t next_insert_id; |
|
218 |
/**
|
|
219 |
insert id for the current row (*autogenerated*; if not
|
|
220 |
autogenerated, it's 0).
|
|
221 |
At first successful insertion, this variable is stored into
|
|
520.1.21
by Brian Aker
THD -> Session rename |
222 |
Session::first_successful_insert_id_in_cur_stmt.
|
1
by brian
clean slate |
223 |
*/
|
224 |
uint64_t insert_id_for_cur_row; |
|
225 |
/**
|
|
226 |
Interval returned by get_auto_increment() and being consumed by the
|
|
227 |
inserter.
|
|
228 |
*/
|
|
229 |
Discrete_interval auto_inc_interval_for_cur_row; |
|
230 |
||
231 |
handler(handlerton *ht_arg, TABLE_SHARE *share_arg) |
|
232 |
:table_share(share_arg), table(0), |
|
233 |
estimation_rows_to_insert(0), ht(ht_arg), |
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
234 |
ref(0), in_range_check_pushed_down(false), |
1
by brian
clean slate |
235 |
key_used_on_scan(MAX_KEY), active_index(MAX_KEY), |
236 |
ref_length(sizeof(my_off_t)), |
|
137
by Brian Aker
Removed dead FT bits. Small refactoring in sql_plugin.cc |
237 |
inited(NONE), |
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
238 |
locked(false), implicit_emptied(0), |
1
by brian
clean slate |
239 |
pushed_cond(0), pushed_idx_cond(NULL), pushed_idx_cond_keyno(MAX_KEY), |
240 |
next_insert_id(0), insert_id_for_cur_row(0) |
|
241 |
{}
|
|
242 |
virtual ~handler(void) |
|
243 |
{
|
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
244 |
assert(locked == false); |
245 |
/* TODO: assert(inited == NONE); */
|
|
1
by brian
clean slate |
246 |
}
|
247 |
virtual handler *clone(MEM_ROOT *mem_root); |
|
248 |
/** This is called after create to allow us to set up cached variables */
|
|
249 |
void init() |
|
250 |
{
|
|
251 |
cached_table_flags= table_flags(); |
|
252 |
}
|
|
575.1.4
by Monty Taylor
Moved implementation of some methods into handler.cc from handler.h. |
253 |
|
1
by brian
clean slate |
254 |
/* ha_ methods: pubilc wrappers for private virtual API */
|
255 |
||
327.1.5
by Brian Aker
Refactor around classes. TABLE_LIST has been factored out of table.h |
256 |
int ha_open(Table *table, const char *name, int mode, int test_if_locked); |
575.1.4
by Monty Taylor
Moved implementation of some methods into handler.cc from handler.h. |
257 |
int ha_index_init(uint32_t idx, bool sorted); |
258 |
int ha_index_end(); |
|
259 |
int ha_rnd_init(bool scan); |
|
260 |
int ha_rnd_end(); |
|
1
by brian
clean slate |
261 |
int ha_reset(); |
575.1.4
by Monty Taylor
Moved implementation of some methods into handler.cc from handler.h. |
262 |
|
1
by brian
clean slate |
263 |
/* this is necessary in many places, e.g. in HANDLER command */
|
575.1.4
by Monty Taylor
Moved implementation of some methods into handler.cc from handler.h. |
264 |
int ha_index_or_rnd_end(); |
265 |
Table_flags ha_table_flags() const; |
|
266 |
||
1
by brian
clean slate |
267 |
/**
|
268 |
These functions represent the public interface to *users* of the
|
|
269 |
handler class, hence they are *not* virtual. For the inheritance
|
|
270 |
interface, see the (private) functions write_row(), update_row(),
|
|
271 |
and delete_row() below.
|
|
272 |
*/
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
273 |
int ha_external_lock(Session *session, int lock_type); |
481
by Brian Aker
Remove all of uchar. |
274 |
int ha_write_row(unsigned char * buf); |
275 |
int ha_update_row(const unsigned char * old_data, unsigned char * new_data); |
|
276 |
int ha_delete_row(const unsigned char * buf); |
|
1
by brian
clean slate |
277 |
void ha_release_auto_increment(); |
278 |
||
279 |
int ha_check_for_upgrade(HA_CHECK_OPT *check_opt); |
|
280 |
/** to be actually called to get 'check()' functionality*/
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
281 |
int ha_check(Session *session, HA_CHECK_OPT *check_opt); |
282 |
int ha_repair(Session* session, HA_CHECK_OPT* check_opt); |
|
575.1.4
by Monty Taylor
Moved implementation of some methods into handler.cc from handler.h. |
283 |
void ha_start_bulk_insert(ha_rows rows); |
284 |
int ha_end_bulk_insert(); |
|
481
by Brian Aker
Remove all of uchar. |
285 |
int ha_bulk_update_row(const unsigned char *old_data, unsigned char *new_data, |
482
by Brian Aker
Remove uint. |
286 |
uint32_t *dup_key_found); |
1
by brian
clean slate |
287 |
int ha_delete_all_rows(); |
288 |
int ha_reset_auto_increment(uint64_t value); |
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
289 |
int ha_optimize(Session* session, HA_CHECK_OPT* check_opt); |
290 |
int ha_analyze(Session* session, HA_CHECK_OPT* check_opt); |
|
291 |
bool ha_check_and_repair(Session *session); |
|
482
by Brian Aker
Remove uint. |
292 |
int ha_disable_indexes(uint32_t mode); |
293 |
int ha_enable_indexes(uint32_t mode); |
|
200
by Brian Aker
my_bool from handler and set_var |
294 |
int ha_discard_or_import_tablespace(bool discard); |
1
by brian
clean slate |
295 |
void ha_prepare_for_alter(); |
296 |
int ha_rename_table(const char *from, const char *to); |
|
297 |
int ha_delete_table(const char *name); |
|
298 |
void ha_drop_table(const char *name); |
|
299 |
||
327.1.5
by Brian Aker
Refactor around classes. TABLE_LIST has been factored out of table.h |
300 |
int ha_create(const char *name, Table *form, HA_CREATE_INFO *info); |
1
by brian
clean slate |
301 |
|
302 |
int ha_create_handler_files(const char *name, const char *old_name, |
|
303 |
int action_flag, HA_CREATE_INFO *info); |
|
304 |
||
305 |
void adjust_next_insert_id_after_explicit_value(uint64_t nr); |
|
306 |
int update_auto_increment(); |
|
482
by Brian Aker
Remove uint. |
307 |
void print_keydup_error(uint32_t key_nr, const char *msg); |
1
by brian
clean slate |
308 |
virtual void print_error(int error, myf errflag); |
309 |
virtual bool get_error_message(int error, String *buf); |
|
482
by Brian Aker
Remove uint. |
310 |
uint32_t get_dup_key(int error); |
575.1.4
by Monty Taylor
Moved implementation of some methods into handler.cc from handler.h. |
311 |
virtual void change_table_ptr(Table *table_arg, TABLE_SHARE *share); |
312 |
||
1
by brian
clean slate |
313 |
/* Estimates calculation */
|
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
314 |
virtual double scan_time(void) |
151
by Brian Aker
Ulonglong to uint64_t |
315 |
{ return uint64_t2double(stats.data_file_length) / IO_SIZE + 2; } |
645
by Brian Aker
Cleanup unused attribute |
316 |
virtual double read_time(uint32_t, uint32_t ranges, ha_rows rows) |
1
by brian
clean slate |
317 |
{ return rows2double(ranges+rows); } |
318 |
||
482
by Brian Aker
Remove uint. |
319 |
virtual double index_only_read_time(uint32_t keynr, double records); |
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
320 |
|
482
by Brian Aker
Remove uint. |
321 |
virtual ha_rows multi_range_read_info_const(uint32_t keyno, RANGE_SEQ_IF *seq, |
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
322 |
void *seq_init_param, |
482
by Brian Aker
Remove uint. |
323 |
uint32_t n_ranges, uint32_t *bufsz, |
324 |
uint32_t *flags, COST_VECT *cost); |
|
325 |
virtual int multi_range_read_info(uint32_t keyno, uint32_t n_ranges, uint32_t keys, |
|
326 |
uint32_t *bufsz, uint32_t *flags, COST_VECT *cost); |
|
1
by brian
clean slate |
327 |
virtual int multi_range_read_init(RANGE_SEQ_IF *seq, void *seq_init_param, |
482
by Brian Aker
Remove uint. |
328 |
uint32_t n_ranges, uint32_t mode, |
1
by brian
clean slate |
329 |
HANDLER_BUFFER *buf); |
330 |
virtual int multi_range_read_next(char **range_info); |
|
331 |
||
332 |
||
575.1.4
by Monty Taylor
Moved implementation of some methods into handler.cc from handler.h. |
333 |
virtual const key_map *keys_to_use_for_scanning(); |
334 |
bool has_transactions(); |
|
482
by Brian Aker
Remove uint. |
335 |
virtual uint32_t extra_rec_buf_length() const { return 0; } |
1
by brian
clean slate |
336 |
|
337 |
/**
|
|
338 |
This method is used to analyse the error to see whether the error
|
|
339 |
is ignorable or not, certain handlers can have more error that are
|
|
340 |
ignorable than others. E.g. the partition handler can get inserts
|
|
341 |
into a range where there is no partition and this is an ignorable
|
|
342 |
error.
|
|
343 |
HA_ERR_FOUND_DUP_UNIQUE is a special case in MyISAM that means the
|
|
344 |
same thing as HA_ERR_FOUND_DUP_KEY but can in some cases lead to
|
|
345 |
a slightly different error message.
|
|
346 |
*/
|
|
575.1.4
by Monty Taylor
Moved implementation of some methods into handler.cc from handler.h. |
347 |
virtual bool is_fatal_error(int error, uint32_t flags); |
1
by brian
clean slate |
348 |
|
349 |
/**
|
|
350 |
Number of rows in table. It will only be called if
|
|
351 |
(table_flags() & (HA_HAS_RECORDS | HA_STATS_RECORDS_IS_EXACT)) != 0
|
|
352 |
*/
|
|
575.1.5
by Monty Taylor
Moved stuff to handlerton.cc |
353 |
virtual ha_rows records(); |
1
by brian
clean slate |
354 |
/**
|
355 |
Return upper bound of current number of records in the table
|
|
356 |
(max. of how many records one will retrieve when doing a full table scan)
|
|
357 |
If upper bound is not known, HA_POS_ERROR should be returned as a max
|
|
358 |
possible upper bound.
|
|
359 |
*/
|
|
360 |
virtual ha_rows estimate_rows_upper_bound() |
|
361 |
{ return stats.records+EXTRA_RECORDS; } |
|
362 |
||
363 |
/**
|
|
364 |
Get the row type from the storage engine. If this method returns
|
|
365 |
ROW_TYPE_NOT_USED, the information in HA_CREATE_INFO should be used.
|
|
366 |
*/
|
|
367 |
virtual enum row_type get_row_type() const { return ROW_TYPE_NOT_USED; } |
|
368 |
||
645
by Brian Aker
Cleanup unused attribute |
369 |
virtual const char *index_type(uint32_t) |
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
370 |
{ assert(0); return "";} |
1
by brian
clean slate |
371 |
|
372 |
||
373 |
/**
|
|
374 |
Signal that the table->read_set and table->write_set table maps changed
|
|
375 |
The handler is allowed to set additional bits in the above map in this
|
|
376 |
call. Normally the handler should ignore all calls until we have done
|
|
377 |
a ha_rnd_init() or ha_index_init(), write_row(), update_row or delete_row()
|
|
378 |
as there may be several calls to this routine.
|
|
379 |
*/
|
|
380 |
virtual void column_bitmaps_signal(); |
|
482
by Brian Aker
Remove uint. |
381 |
uint32_t get_index(void) const { return active_index; } |
1
by brian
clean slate |
382 |
virtual int close(void)=0; |
383 |
||
384 |
/**
|
|
385 |
@retval 0 Bulk update used by handler
|
|
386 |
@retval 1 Bulk update not used, normal operation used
|
|
387 |
*/
|
|
388 |
virtual bool start_bulk_update() { return 1; } |
|
389 |
/**
|
|
390 |
@retval 0 Bulk delete used by handler
|
|
391 |
@retval 1 Bulk delete not used, normal operation used
|
|
392 |
*/
|
|
393 |
virtual bool start_bulk_delete() { return 1; } |
|
394 |
/**
|
|
395 |
After this call all outstanding updates must be performed. The number
|
|
396 |
of duplicate key errors are reported in the duplicate key parameter.
|
|
397 |
It is allowed to continue to the batched update after this call, the
|
|
398 |
handler has to wait until end_bulk_update with changing state.
|
|
399 |
||
400 |
@param dup_key_found Number of duplicate keys found
|
|
401 |
||
402 |
@retval 0 Success
|
|
403 |
@retval >0 Error code
|
|
404 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
405 |
virtual int exec_bulk_update(uint32_t *) |
1
by brian
clean slate |
406 |
{
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
407 |
assert(false); |
1
by brian
clean slate |
408 |
return HA_ERR_WRONG_COMMAND; |
409 |
}
|
|
410 |
/**
|
|
411 |
Perform any needed clean-up, no outstanding updates are there at the
|
|
412 |
moment.
|
|
413 |
*/
|
|
414 |
virtual void end_bulk_update() { return; } |
|
415 |
/**
|
|
416 |
Execute all outstanding deletes and close down the bulk delete.
|
|
417 |
||
418 |
@retval 0 Success
|
|
419 |
@retval >0 Error code
|
|
420 |
*/
|
|
421 |
virtual int end_bulk_delete() |
|
422 |
{
|
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
423 |
assert(false); |
1
by brian
clean slate |
424 |
return HA_ERR_WRONG_COMMAND; |
425 |
}
|
|
426 |
/**
|
|
427 |
@brief
|
|
428 |
Positions an index cursor to the index specified in the handle. Fetches the
|
|
429 |
row if available. If the key value is null, begin at the first key of the
|
|
430 |
index.
|
|
431 |
*/
|
|
481
by Brian Aker
Remove all of uchar. |
432 |
virtual int index_read_map(unsigned char * buf, const unsigned char * key, |
1
by brian
clean slate |
433 |
key_part_map keypart_map, |
434 |
enum ha_rkey_function find_flag) |
|
435 |
{
|
|
482
by Brian Aker
Remove uint. |
436 |
uint32_t key_len= calculate_key_len(table, active_index, key, keypart_map); |
1
by brian
clean slate |
437 |
return index_read(buf, key, key_len, find_flag); |
438 |
}
|
|
439 |
/**
|
|
440 |
@brief
|
|
441 |
Positions an index cursor to the index specified in the handle. Fetches the
|
|
442 |
row if available. If the key value is null, begin at the first key of the
|
|
443 |
index.
|
|
444 |
*/
|
|
656.1.1
by Monty Taylor
OOOh doggie. Got rid of my_alloca. |
445 |
virtual int index_read_idx_map(unsigned char * buf, uint32_t index, |
446 |
const unsigned char * key, |
|
1
by brian
clean slate |
447 |
key_part_map keypart_map, |
448 |
enum ha_rkey_function find_flag); |
|
645
by Brian Aker
Cleanup unused attribute |
449 |
virtual int index_next(unsigned char *) |
450 |
{ return HA_ERR_WRONG_COMMAND; } |
|
451 |
virtual int index_prev(unsigned char *) |
|
452 |
{ return HA_ERR_WRONG_COMMAND; } |
|
453 |
virtual int index_first(unsigned char *) |
|
454 |
{ return HA_ERR_WRONG_COMMAND; } |
|
455 |
virtual int index_last(unsigned char *) |
|
456 |
{ return HA_ERR_WRONG_COMMAND; } |
|
457 |
virtual int index_next_same(unsigned char *, const unsigned char *, uint32_t); |
|
1
by brian
clean slate |
458 |
/**
|
459 |
@brief
|
|
460 |
The following functions works like index_read, but it find the last
|
|
461 |
row with the current key value or prefix.
|
|
462 |
*/
|
|
481
by Brian Aker
Remove all of uchar. |
463 |
virtual int index_read_last_map(unsigned char * buf, const unsigned char * key, |
1
by brian
clean slate |
464 |
key_part_map keypart_map) |
465 |
{
|
|
482
by Brian Aker
Remove uint. |
466 |
uint32_t key_len= calculate_key_len(table, active_index, key, keypart_map); |
1
by brian
clean slate |
467 |
return index_read_last(buf, key, key_len); |
468 |
}
|
|
469 |
virtual int read_range_first(const key_range *start_key, |
|
470 |
const key_range *end_key, |
|
471 |
bool eq_range, bool sorted); |
|
472 |
virtual int read_range_next(); |
|
473 |
int compare_key(key_range *range); |
|
474 |
int compare_key2(key_range *range); |
|
645
by Brian Aker
Cleanup unused attribute |
475 |
virtual int rnd_next(unsigned char *)=0; |
476 |
virtual int rnd_pos(unsigned char *, unsigned char *)=0; |
|
1
by brian
clean slate |
477 |
/**
|
478 |
One has to use this method when to find
|
|
479 |
random position by record as the plain
|
|
480 |
position() call doesn't work for some
|
|
481 |
handlers for random position.
|
|
482 |
*/
|
|
481
by Brian Aker
Remove all of uchar. |
483 |
virtual int rnd_pos_by_record(unsigned char *record); |
482
by Brian Aker
Remove uint. |
484 |
virtual int read_first_row(unsigned char *buf, uint32_t primary_key); |
1
by brian
clean slate |
485 |
/**
|
486 |
The following function is only needed for tables that may be temporary
|
|
487 |
tables during joins.
|
|
488 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
489 |
virtual int restart_rnd_next(unsigned char *, unsigned char *) |
490 |
{ return HA_ERR_WRONG_COMMAND; } |
|
491 |
virtual int rnd_same(unsigned char *, uint32_t) |
|
492 |
{ return HA_ERR_WRONG_COMMAND; } |
|
493 |
virtual ha_rows records_in_range(uint32_t, key_range *, key_range *) |
|
1
by brian
clean slate |
494 |
{ return (ha_rows) 10; } |
481
by Brian Aker
Remove all of uchar. |
495 |
virtual void position(const unsigned char *record)=0; |
1
by brian
clean slate |
496 |
virtual int info(uint)=0; // see my_base.h for full description |
645
by Brian Aker
Cleanup unused attribute |
497 |
virtual uint32_t calculate_key_hash_value(Field **) |
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
498 |
{ assert(0); return 0; } |
645
by Brian Aker
Cleanup unused attribute |
499 |
virtual int extra(enum ha_extra_function) |
1
by brian
clean slate |
500 |
{ return 0; } |
645
by Brian Aker
Cleanup unused attribute |
501 |
virtual int extra_opt(enum ha_extra_function operation, uint32_t) |
1
by brian
clean slate |
502 |
{ return extra(operation); } |
503 |
||
504 |
/**
|
|
505 |
In an UPDATE or DELETE, if the row under the cursor was locked by another
|
|
506 |
transaction, and the engine used an optimistic read of the last
|
|
507 |
committed row value under the cursor, then the engine returns 1 from this
|
|
508 |
function. MySQL must NOT try to update this optimistic value. If the
|
|
509 |
optimistic value does not match the WHERE condition, MySQL can decide to
|
|
510 |
skip over this row. Currently only works for InnoDB. This can be used to
|
|
511 |
avoid unnecessary lock waits.
|
|
512 |
||
513 |
If this method returns nonzero, it will also signal the storage
|
|
514 |
engine that the next read will be a locking re-read of the row.
|
|
515 |
*/
|
|
516 |
virtual bool was_semi_consistent_read() { return 0; } |
|
517 |
/**
|
|
518 |
Tell the engine whether it should avoid unnecessary lock waits.
|
|
519 |
If yes, in an UPDATE or DELETE, if the row under the cursor was locked
|
|
520 |
by another transaction, the engine may try an optimistic read of
|
|
521 |
the last committed row value under the cursor.
|
|
522 |
*/
|
|
523 |
virtual void try_semi_consistent_read(bool) {} |
|
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
524 |
virtual void unlock_row(void) {} |
645
by Brian Aker
Cleanup unused attribute |
525 |
virtual int start_stmt(Session *, thr_lock_type) |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
526 |
{return 0;} |
1
by brian
clean slate |
527 |
virtual void get_auto_increment(uint64_t offset, uint64_t increment, |
528 |
uint64_t nb_desired_values, |
|
529 |
uint64_t *first_value, |
|
530 |
uint64_t *nb_reserved_values); |
|
531 |
void set_next_insert_id(uint64_t id) |
|
532 |
{
|
|
533 |
next_insert_id= id; |
|
534 |
}
|
|
535 |
void restore_auto_increment(uint64_t prev_insert_id) |
|
536 |
{
|
|
537 |
/*
|
|
538 |
Insertion of a row failed, re-use the lastly generated auto_increment
|
|
539 |
id, for the next row. This is achieved by resetting next_insert_id to
|
|
540 |
what it was before the failed insertion (that old value is provided by
|
|
541 |
the caller). If that value was 0, it was the first row of the INSERT;
|
|
542 |
then if insert_id_for_cur_row contains 0 it means no id was generated
|
|
543 |
for this first row, so no id was generated since the INSERT started, so
|
|
544 |
we should set next_insert_id to 0; if insert_id_for_cur_row is not 0, it
|
|
545 |
is the generated id of the first and failed row, so we use it.
|
|
546 |
*/
|
|
547 |
next_insert_id= (prev_insert_id > 0) ? prev_insert_id : |
|
548 |
insert_id_for_cur_row; |
|
549 |
}
|
|
550 |
||
645
by Brian Aker
Cleanup unused attribute |
551 |
virtual void update_create_info(HA_CREATE_INFO *) {} |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
552 |
int check_old_types(void); |
645
by Brian Aker
Cleanup unused attribute |
553 |
virtual int assign_to_keycache(Session*, HA_CHECK_OPT *) |
1
by brian
clean slate |
554 |
{ return HA_ADMIN_NOT_IMPLEMENTED; } |
555 |
/* end of the list of admin commands */
|
|
556 |
||
557 |
virtual int indexes_are_disabled(void) {return 0;} |
|
558 |
virtual char *update_table_comment(const char * comment) |
|
559 |
{ return (char*) comment;} |
|
645
by Brian Aker
Cleanup unused attribute |
560 |
virtual void append_create_info(String *) |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
561 |
{}
|
1
by brian
clean slate |
562 |
/**
|
563 |
If index == MAX_KEY then a check for table is made and if index <
|
|
564 |
MAX_KEY then a check is made if the table has foreign keys and if
|
|
565 |
a foreign key uses this index (and thus the index cannot be dropped).
|
|
566 |
||
567 |
@param index Index to check if foreign key uses it
|
|
568 |
||
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
569 |
@retval true Foreign key defined on table or index
|
570 |
@retval false No foreign key defined
|
|
1
by brian
clean slate |
571 |
*/
|
645
by Brian Aker
Cleanup unused attribute |
572 |
virtual bool is_fk_defined_on_table_or_index(uint32_t) |
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
573 |
{ return false; } |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
574 |
virtual char* get_foreign_key_create_info(void) |
1
by brian
clean slate |
575 |
{ return(NULL);} /* gets foreign key create string from InnoDB */ |
327.1.5
by Brian Aker
Refactor around classes. TABLE_LIST has been factored out of table.h |
576 |
/** used in ALTER Table; 1 if changing storage engine is allowed */
|
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
577 |
virtual bool can_switch_engines(void) { return 1; } |
1
by brian
clean slate |
578 |
/** used in REPLACE; is > 0 if table is referred by a FOREIGN KEY */
|
645
by Brian Aker
Cleanup unused attribute |
579 |
virtual int get_foreign_key_list(Session *, List<FOREIGN_KEY_INFO> *) |
1
by brian
clean slate |
580 |
{ return 0; } |
482
by Brian Aker
Remove uint. |
581 |
virtual uint32_t referenced_by_foreign_key() { return 0;} |
1
by brian
clean slate |
582 |
virtual void init_table_handle_for_HANDLER() |
583 |
{ return; } /* prepare InnoDB for HANDLER */ |
|
645
by Brian Aker
Cleanup unused attribute |
584 |
virtual void free_foreign_key_create_info(char *) {} |
1
by brian
clean slate |
585 |
/** The following can be called without an open handler */
|
586 |
virtual const char *table_type() const =0; |
|
587 |
/**
|
|
588 |
If frm_error() is called then we will use this to find out what file
|
|
589 |
extentions exist for the storage engine. This is also used by the default
|
|
590 |
rename_table and delete_table method in handler.cc.
|
|
591 |
||
592 |
For engines that have two file name extentions (separate meta/index file
|
|
593 |
and data file), the order of elements is relevant. First element of engine
|
|
594 |
file name extentions array should be meta/index file extention. Second
|
|
595 |
element - data file extention. This order is assumed by
|
|
327.1.5
by Brian Aker
Refactor around classes. TABLE_LIST has been factored out of table.h |
596 |
prepare_for_repair() when REPAIR Table ... USE_FRM is issued.
|
1
by brian
clean slate |
597 |
*/
|
598 |
virtual const char **bas_ext() const =0; |
|
599 |
||
645
by Brian Aker
Cleanup unused attribute |
600 |
virtual int get_default_no_partitions(HA_CREATE_INFO *) { return 1;} |
601 |
virtual bool get_no_parts(const char *, uint32_t *no_parts) |
|
1
by brian
clean slate |
602 |
{
|
603 |
*no_parts= 0; |
|
604 |
return 0; |
|
605 |
}
|
|
606 |
||
482
by Brian Aker
Remove uint. |
607 |
virtual uint32_t index_flags(uint32_t idx, uint32_t part, bool all_parts) const =0; |
1
by brian
clean slate |
608 |
|
645
by Brian Aker
Cleanup unused attribute |
609 |
virtual int add_index(Table *, KEY *, uint32_t) |
610 |
{ return (HA_ERR_WRONG_COMMAND); } |
|
611 |
virtual int prepare_drop_index(Table *, uint32_t *, uint32_t) |
|
612 |
{ return (HA_ERR_WRONG_COMMAND); } |
|
613 |
virtual int final_drop_index(Table *) |
|
1
by brian
clean slate |
614 |
{ return (HA_ERR_WRONG_COMMAND); } |
615 |
||
482
by Brian Aker
Remove uint. |
616 |
uint32_t max_record_length() const |
398.1.4
by Monty Taylor
Renamed max/min. |
617 |
{ return cmin((unsigned int)HA_MAX_REC_LENGTH, max_supported_record_length()); } |
482
by Brian Aker
Remove uint. |
618 |
uint32_t max_keys() const |
398.1.4
by Monty Taylor
Renamed max/min. |
619 |
{ return cmin((unsigned int)MAX_KEY, max_supported_keys()); } |
482
by Brian Aker
Remove uint. |
620 |
uint32_t max_key_parts() const |
398.1.4
by Monty Taylor
Renamed max/min. |
621 |
{ return cmin((unsigned int)MAX_REF_PARTS, max_supported_key_parts()); } |
482
by Brian Aker
Remove uint. |
622 |
uint32_t max_key_length() const |
398.1.4
by Monty Taylor
Renamed max/min. |
623 |
{ return cmin((unsigned int)MAX_KEY_LENGTH, max_supported_key_length()); } |
482
by Brian Aker
Remove uint. |
624 |
uint32_t max_key_part_length(void) const |
398.1.4
by Monty Taylor
Renamed max/min. |
625 |
{ return cmin((unsigned int)MAX_KEY_LENGTH, max_supported_key_part_length()); } |
1
by brian
clean slate |
626 |
|
482
by Brian Aker
Remove uint. |
627 |
virtual uint32_t max_supported_record_length(void) const |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
628 |
{ return HA_MAX_REC_LENGTH; } |
482
by Brian Aker
Remove uint. |
629 |
virtual uint32_t max_supported_keys(void) const { return 0; } |
630 |
virtual uint32_t max_supported_key_parts(void) const { return MAX_REF_PARTS; } |
|
631 |
virtual uint32_t max_supported_key_length(void) const { return MAX_KEY_LENGTH; } |
|
632 |
virtual uint32_t max_supported_key_part_length(void) const { return 255; } |
|
645
by Brian Aker
Cleanup unused attribute |
633 |
virtual uint32_t min_record_length(uint32_t) const |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
634 |
{ return 1; } |
1
by brian
clean slate |
635 |
|
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
636 |
virtual bool low_byte_first(void) const { return 1; } |
482
by Brian Aker
Remove uint. |
637 |
virtual uint32_t checksum(void) const { return 0; } |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
638 |
virtual bool is_crashed(void) const { return 0; } |
639 |
virtual bool auto_repair(void) const { return 0; } |
|
1
by brian
clean slate |
640 |
|
641 |
||
642 |
#define CHF_CREATE_FLAG 0
|
|
643 |
#define CHF_DELETE_FLAG 1
|
|
644 |
#define CHF_RENAME_FLAG 2
|
|
645 |
||
646 |
||
647 |
/**
|
|
648 |
@note lock_count() can return > 1 if the table is MERGE or partitioned.
|
|
649 |
*/
|
|
482
by Brian Aker
Remove uint. |
650 |
virtual uint32_t lock_count(void) const { return 1; } |
1
by brian
clean slate |
651 |
/**
|
652 |
Is not invoked for non-transactional temporary tables.
|
|
653 |
||
654 |
@note store_lock() can return more than one lock if the table is MERGE
|
|
655 |
or partitioned.
|
|
656 |
||
657 |
@note that one can NOT rely on table->in_use in store_lock(). It may
|
|
658 |
refer to a different thread if called from mysql_lock_abort_for_thread().
|
|
659 |
||
660 |
@note If the table is MERGE, store_lock() can return less locks
|
|
661 |
than lock_count() claimed. This can happen when the MERGE children
|
|
662 |
are not attached when this is called from another thread.
|
|
663 |
*/
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
664 |
virtual THR_LOCK_DATA **store_lock(Session *session, |
1
by brian
clean slate |
665 |
THR_LOCK_DATA **to, |
666 |
enum thr_lock_type lock_type)=0; |
|
667 |
||
668 |
/** Type of table for caching query */
|
|
206
by Brian Aker
Removed final uint dead types. |
669 |
virtual uint8_t table_cache_type() { return HA_CACHE_TBL_NONTRANSACT; } |
1
by brian
clean slate |
670 |
|
671 |
||
672 |
/**
|
|
673 |
@brief Register a named table with a call back function to the query cache.
|
|
674 |
||
520.1.22
by Brian Aker
Second pass of thd cleanup |
675 |
@param session The thread handle
|
1
by brian
clean slate |
676 |
@param table_key A pointer to the table name in the table cache
|
677 |
@param key_length The length of the table name
|
|
678 |
@param[out] engine_callback The pointer to the storage engine call back
|
|
679 |
function
|
|
680 |
@param[out] engine_data Storage engine specific data which could be
|
|
681 |
anything
|
|
682 |
||
683 |
This method offers the storage engine, the possibility to store a reference
|
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
684 |
to a table name which is going to be used with query cache.
|
1
by brian
clean slate |
685 |
The method is called each time a statement is written to the cache and can
|
686 |
be used to verify if a specific statement is cachable. It also offers
|
|
687 |
the possibility to register a generic (but static) call back function which
|
|
688 |
is called each time a statement is matched against the query cache.
|
|
689 |
||
690 |
@note If engine_data supplied with this function is different from
|
|
691 |
engine_data supplied with the callback function, and the callback returns
|
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
692 |
false, a table invalidation on the current table will occur.
|
1
by brian
clean slate |
693 |
|
694 |
@return Upon success the engine_callback will point to the storage engine
|
|
695 |
call back function, if any, and engine_data will point to any storage
|
|
696 |
engine data used in the specific implementation.
|
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
697 |
@retval true Success
|
698 |
@retval false The specified table or current statement should not be
|
|
1
by brian
clean slate |
699 |
cached
|
700 |
*/
|
|
701 |
||
200
by Brian Aker
my_bool from handler and set_var |
702 |
virtual bool |
645
by Brian Aker
Cleanup unused attribute |
703 |
register_query_cache_table(Session *, char *, uint32_t, |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
704 |
qc_engine_callback *engine_callback, |
645
by Brian Aker
Cleanup unused attribute |
705 |
uint64_t *) |
1
by brian
clean slate |
706 |
{
|
707 |
*engine_callback= 0; |
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
708 |
return true; |
1
by brian
clean slate |
709 |
}
|
710 |
||
711 |
||
712 |
/*
|
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
713 |
@retval true Primary key (if there is one) is clustered
|
1
by brian
clean slate |
714 |
key covering all fields
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
715 |
@retval false otherwise
|
1
by brian
clean slate |
716 |
*/
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
717 |
virtual bool primary_key_is_clustered() { return false; } |
481
by Brian Aker
Remove all of uchar. |
718 |
virtual int cmp_ref(const unsigned char *ref1, const unsigned char *ref2) |
1
by brian
clean slate |
719 |
{
|
720 |
return memcmp(ref1, ref2, ref_length); |
|
721 |
}
|
|
722 |
||
723 |
/*
|
|
724 |
Condition pushdown to storage engines
|
|
725 |
*/
|
|
726 |
||
727 |
/**
|
|
728 |
Push condition down to the table handler.
|
|
729 |
||
730 |
@param cond Condition to be pushed. The condition tree must not be
|
|
731 |
modified by the by the caller.
|
|
732 |
||
733 |
@return
|
|
734 |
The 'remainder' condition that caller must use to filter out records.
|
|
735 |
NULL means the handler will not return rows that do not match the
|
|
736 |
passed condition.
|
|
737 |
||
738 |
@note
|
|
739 |
The pushed conditions form a stack (from which one can remove the
|
|
740 |
last pushed condition using cond_pop).
|
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
741 |
The table handler filters out rows using (pushed_cond1 AND pushed_cond2
|
1
by brian
clean slate |
742 |
AND ... AND pushed_condN)
|
743 |
or less restrictive condition, depending on handler's capabilities.
|
|
744 |
||
745 |
handler->ha_reset() call empties the condition stack.
|
|
746 |
Calls to rnd_init/rnd_end, index_init/index_end etc do not affect the
|
|
747 |
condition stack.
|
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
748 |
*/
|
1
by brian
clean slate |
749 |
virtual const COND *cond_push(const COND *cond) { return cond; } |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
750 |
|
1
by brian
clean slate |
751 |
/**
|
752 |
Pop the top condition from the condition stack of the handler instance.
|
|
753 |
||
754 |
Pops the top if condition stack, if stack is not empty.
|
|
755 |
*/
|
|
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
756 |
virtual void cond_pop(void) { return; } |
1
by brian
clean slate |
757 |
|
645
by Brian Aker
Cleanup unused attribute |
758 |
virtual Item *idx_cond_push(uint32_t, Item *idx_cond) |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
759 |
{ return idx_cond; } |
1
by brian
clean slate |
760 |
|
761 |
/*
|
|
762 |
Part of old fast alter table, to be depricated
|
|
763 |
*/
|
|
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
764 |
virtual bool |
645
by Brian Aker
Cleanup unused attribute |
765 |
check_if_incompatible_data(HA_CREATE_INFO *, uint32_t) |
1
by brian
clean slate |
766 |
{ return COMPATIBLE_DATA_NO; } |
767 |
||
327.1.5
by Brian Aker
Refactor around classes. TABLE_LIST has been factored out of table.h |
768 |
/* On-line ALTER Table interface */
|
1
by brian
clean slate |
769 |
|
770 |
/**
|
|
771 |
Check if a storage engine supports a particular alter table on-line
|
|
772 |
||
773 |
@param altered_table A temporary table show what table is to
|
|
774 |
change to
|
|
775 |
@param create_info Information from the parsing phase about new
|
|
776 |
table properties.
|
|
777 |
@param alter_flags Bitmask that shows what will be changed
|
|
778 |
@param table_changes Shows if table layout has changed (for
|
|
779 |
backwards compatibility with
|
|
780 |
check_if_incompatible_data
|
|
781 |
||
782 |
@retval HA_ALTER_ERROR Unexpected error
|
|
783 |
@retval HA_ALTER_SUPPORTED_WAIT_LOCK Supported, but requires DDL lock
|
|
784 |
@retval HA_ALTER_SUPPORTED_NO_LOCK Supported
|
|
785 |
@retval HA_ALTER_NOT_SUPPORTED Not supported
|
|
786 |
||
787 |
@note
|
|
788 |
The default implementation is implemented to support fast
|
|
789 |
alter table (storage engines that support some changes by
|
|
790 |
just changing the frm file) without any change in the handler
|
|
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
791 |
implementation.
|
1
by brian
clean slate |
792 |
*/
|
645
by Brian Aker
Cleanup unused attribute |
793 |
virtual int check_if_supported_alter(Table *, HA_CREATE_INFO *create_info, |
794 |
HA_ALTER_FLAGS * alter_flags, uint32_t table_changes) |
|
1
by brian
clean slate |
795 |
{
|
796 |
if (this->check_if_incompatible_data(create_info, table_changes) |
|
797 |
== COMPATIBLE_DATA_NO) |
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
798 |
return(HA_ALTER_NOT_SUPPORTED); |
383.7.1
by Andrey Zhakov
Initial submit of code and tests |
799 |
else if ((*alter_flags & HA_ALTER_STORED_VCOL).is_set()) |
800 |
return(HA_ALTER_NOT_SUPPORTED); |
|
1
by brian
clean slate |
801 |
else
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
802 |
return(HA_ALTER_SUPPORTED_WAIT_LOCK); |
1
by brian
clean slate |
803 |
}
|
804 |
/**
|
|
805 |
Tell storage engine to prepare for the on-line alter table (pre-alter)
|
|
806 |
||
520.1.22
by Brian Aker
Second pass of thd cleanup |
807 |
@param session The thread handle
|
1
by brian
clean slate |
808 |
@param altered_table A temporary table show what table is to
|
809 |
change to
|
|
810 |
@param alter_info Storage place for data used during phase1
|
|
811 |
and phase2
|
|
812 |
@param alter_flags Bitmask that shows what will be changed
|
|
813 |
||
814 |
@retval 0 OK
|
|
815 |
@retval error error code passed from storage engine
|
|
816 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
817 |
virtual int alter_table_phase1(Session *, Table *, HA_CREATE_INFO *, HA_ALTER_INFO *, |
818 |
HA_ALTER_FLAGS *) |
|
1
by brian
clean slate |
819 |
{
|
820 |
return HA_ERR_UNSUPPORTED; |
|
821 |
}
|
|
822 |
/**
|
|
823 |
Tell storage engine to perform the on-line alter table (alter)
|
|
824 |
||
520.1.22
by Brian Aker
Second pass of thd cleanup |
825 |
@param session The thread handle
|
1
by brian
clean slate |
826 |
@param altered_table A temporary table show what table is to
|
827 |
change to
|
|
828 |
@param alter_info Storage place for data used during phase1
|
|
829 |
and phase2
|
|
830 |
@param alter_flags Bitmask that shows what will be changed
|
|
831 |
||
832 |
@retval 0 OK
|
|
833 |
@retval error error code passed from storage engine
|
|
834 |
||
835 |
@note
|
|
836 |
If check_if_supported_alter returns HA_ALTER_SUPPORTED_WAIT_LOCK
|
|
837 |
this call is to be wrapped with a DDL lock. This is currently NOT
|
|
838 |
supported.
|
|
839 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
840 |
virtual int alter_table_phase2(Session *, Table *, HA_CREATE_INFO *, HA_ALTER_INFO *, |
841 |
HA_ALTER_FLAGS *) |
|
1
by brian
clean slate |
842 |
{
|
843 |
return HA_ERR_UNSUPPORTED; |
|
844 |
}
|
|
845 |
/**
|
|
846 |
Tell storage engine that changed frm file is now on disk and table
|
|
847 |
has been re-opened (post-alter)
|
|
848 |
||
520.1.22
by Brian Aker
Second pass of thd cleanup |
849 |
@param session The thread handle
|
1
by brian
clean slate |
850 |
@param table The altered table, re-opened
|
851 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
852 |
virtual int alter_table_phase3(Session *, Table *) |
1
by brian
clean slate |
853 |
{
|
854 |
return HA_ERR_UNSUPPORTED; |
|
855 |
}
|
|
856 |
||
857 |
/**
|
|
858 |
use_hidden_primary_key() is called in case of an update/delete when
|
|
859 |
(table_flags() and HA_PRIMARY_KEY_REQUIRED_FOR_DELETE) is defined
|
|
860 |
but we don't have a primary key
|
|
861 |
*/
|
|
862 |
virtual void use_hidden_primary_key(); |
|
863 |
||
864 |
/**
|
|
865 |
Lock table.
|
|
866 |
||
520.1.22
by Brian Aker
Second pass of thd cleanup |
867 |
@param session Thread handle
|
1
by brian
clean slate |
868 |
@param lock_type HA_LOCK_IN_SHARE_MODE (F_RDLCK)
|
869 |
HA_LOCK_IN_EXCLUSIVE_MODE (F_WRLCK)
|
|
870 |
@param lock_timeout -1 default timeout
|
|
871 |
0 no wait
|
|
872 |
>0 wait timeout in milliseconds.
|
|
873 |
||
874 |
@note
|
|
875 |
lock_timeout >0 is not used by MySQL currently. If the storage
|
|
876 |
engine does not support NOWAIT (lock_timeout == 0) it should
|
|
877 |
return an error. But if it does not support WAIT X (lock_timeout
|
|
878 |
>0) it should treat it as lock_timeout == -1 and wait a default
|
|
879 |
(or even hard-coded) timeout.
|
|
880 |
||
881 |
@retval HA_ERR_WRONG_COMMAND Storage engine does not support
|
|
882 |
lock_table()
|
|
883 |
@retval HA_ERR_UNSUPPORTED Storage engine does not support NOWAIT
|
|
884 |
@retval HA_ERR_LOCK_WAIT_TIMEOUT Lock request timed out or
|
|
885 |
lock conflict with NOWAIT option
|
|
886 |
@retval HA_ERR_LOCK_DEADLOCK Deadlock detected
|
|
887 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
888 |
virtual int lock_table(Session *, int, int) |
1
by brian
clean slate |
889 |
{
|
890 |
return HA_ERR_WRONG_COMMAND; |
|
891 |
}
|
|
383.7.1
by Andrey Zhakov
Initial submit of code and tests |
892 |
/*
|
893 |
This procedure defines if the storage engine supports virtual columns.
|
|
894 |
Default false means "not supported".
|
|
895 |
*/
|
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
896 |
virtual bool check_if_supported_virtual_columns(void) |
383.7.1
by Andrey Zhakov
Initial submit of code and tests |
897 |
{ return false; } |
1
by brian
clean slate |
898 |
|
899 |
protected: |
|
900 |
/* Service methods for use by storage engines. */
|
|
901 |
void ha_statistic_increment(ulong SSV::*offset) const; |
|
520.1.21
by Brian Aker
THD -> Session rename |
902 |
void **ha_data(Session *) const; |
520.1.22
by Brian Aker
Second pass of thd cleanup |
903 |
Session *ha_session(void) const; |
1
by brian
clean slate |
904 |
|
905 |
/**
|
|
906 |
Default rename_table() and delete_table() rename/delete files with a
|
|
907 |
given name and extensions from bas_ext().
|
|
908 |
||
909 |
These methods can be overridden, but their default implementation
|
|
910 |
provide useful functionality.
|
|
911 |
*/
|
|
912 |
virtual int rename_table(const char *from, const char *to); |
|
913 |
/**
|
|
914 |
Delete a table in the engine. Called for base as well as temporary
|
|
915 |
tables.
|
|
916 |
*/
|
|
917 |
virtual int delete_table(const char *name); |
|
918 |
||
919 |
private: |
|
920 |
/* Private helpers */
|
|
921 |
inline void mark_trx_read_write(); |
|
922 |
private: |
|
923 |
/*
|
|
924 |
Low-level primitives for storage engines. These should be
|
|
925 |
overridden by the storage engine class. To call these methods, use
|
|
926 |
the corresponding 'ha_*' method above.
|
|
927 |
*/
|
|
928 |
||
482
by Brian Aker
Remove uint. |
929 |
virtual int open(const char *name, int mode, uint32_t test_if_locked)=0; |
645
by Brian Aker
Cleanup unused attribute |
930 |
virtual int index_init(uint32_t idx, bool) |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
931 |
{ active_index= idx; return 0; } |
1
by brian
clean slate |
932 |
virtual int index_end() { active_index= MAX_KEY; return 0; } |
933 |
/**
|
|
934 |
rnd_init() can be called two times without rnd_end() in between
|
|
935 |
(it only makes sense if scan=1).
|
|
936 |
then the second call should prepare for the new table scan (e.g
|
|
937 |
if rnd_init allocates the cursor, second call should position it
|
|
938 |
to the start of the table, no need to deallocate and allocate it again
|
|
939 |
*/
|
|
940 |
virtual int rnd_init(bool scan)= 0; |
|
941 |
virtual int rnd_end() { return 0; } |
|
645
by Brian Aker
Cleanup unused attribute |
942 |
virtual int write_row(unsigned char *) |
943 |
{
|
|
944 |
return HA_ERR_WRONG_COMMAND; |
|
945 |
}
|
|
946 |
||
947 |
virtual int update_row(const unsigned char *, unsigned char *) |
|
948 |
{
|
|
949 |
return HA_ERR_WRONG_COMMAND; |
|
950 |
}
|
|
951 |
||
952 |
virtual int delete_row(const unsigned char *) |
|
1
by brian
clean slate |
953 |
{
|
954 |
return HA_ERR_WRONG_COMMAND; |
|
955 |
}
|
|
956 |
/**
|
|
957 |
Reset state of file to after 'open'.
|
|
958 |
This function is called after every statement for all tables used
|
|
959 |
by that statement.
|
|
960 |
*/
|
|
961 |
virtual int reset() { return 0; } |
|
962 |
virtual Table_flags table_flags(void) const= 0; |
|
963 |
||
964 |
/**
|
|
965 |
Is not invoked for non-transactional temporary tables.
|
|
966 |
||
967 |
Tells the storage engine that we intend to read or write data
|
|
968 |
from the table. This call is prefixed with a call to handler::store_lock()
|
|
969 |
and is invoked only for those handler instances that stored the lock.
|
|
970 |
||
971 |
Calls to rnd_init/index_init are prefixed with this call. When table
|
|
972 |
IO is complete, we call external_lock(F_UNLCK).
|
|
973 |
A storage engine writer should expect that each call to
|
|
974 |
::external_lock(F_[RD|WR]LOCK is followed by a call to
|
|
975 |
::external_lock(F_UNLCK). If it is not, it is a bug in MySQL.
|
|
976 |
||
977 |
The name and signature originate from the first implementation
|
|
978 |
in MyISAM, which would call fcntl to set/clear an advisory
|
|
979 |
lock on the data file in this method.
|
|
980 |
||
981 |
@param lock_type F_RDLCK, F_WRLCK, F_UNLCK
|
|
982 |
||
983 |
@return non-0 in case of failure, 0 in case of success.
|
|
984 |
When lock_type is F_UNLCK, the return value is ignored.
|
|
985 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
986 |
virtual int external_lock(Session *, int) |
1
by brian
clean slate |
987 |
{
|
988 |
return 0; |
|
989 |
}
|
|
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
990 |
virtual void release_auto_increment(void) { return; }; |
1
by brian
clean slate |
991 |
/** admin commands - called from mysql_admin_table */
|
645
by Brian Aker
Cleanup unused attribute |
992 |
virtual int check_for_upgrade(HA_CHECK_OPT *) |
1
by brian
clean slate |
993 |
{ return 0; } |
645
by Brian Aker
Cleanup unused attribute |
994 |
virtual int check(Session *, HA_CHECK_OPT *) |
1
by brian
clean slate |
995 |
{ return HA_ADMIN_NOT_IMPLEMENTED; } |
996 |
||
997 |
/**
|
|
998 |
In this method check_opt can be modified
|
|
999 |
to specify CHECK option to use to call check()
|
|
1000 |
upon the table.
|
|
1001 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
1002 |
virtual int repair(Session *, HA_CHECK_OPT *) |
1
by brian
clean slate |
1003 |
{ return HA_ADMIN_NOT_IMPLEMENTED; } |
645
by Brian Aker
Cleanup unused attribute |
1004 |
virtual void start_bulk_insert(ha_rows) |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
1005 |
{}
|
1006 |
virtual int end_bulk_insert(void) { return 0; } |
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
1007 |
virtual int index_read(unsigned char *, const unsigned char *, |
645
by Brian Aker
Cleanup unused attribute |
1008 |
uint32_t, enum ha_rkey_function) |
1
by brian
clean slate |
1009 |
{ return HA_ERR_WRONG_COMMAND; } |
645
by Brian Aker
Cleanup unused attribute |
1010 |
virtual int index_read_last(unsigned char *, const unsigned char *, uint32_t) |
1
by brian
clean slate |
1011 |
{ return (my_errno= HA_ERR_WRONG_COMMAND); } |
1012 |
/**
|
|
1013 |
This method is similar to update_row, however the handler doesn't need
|
|
1014 |
to execute the updates at this point in time. The handler can be certain
|
|
1015 |
that another call to bulk_update_row will occur OR a call to
|
|
1016 |
exec_bulk_update before the set of updates in this query is concluded.
|
|
1017 |
||
1018 |
@param old_data Old record
|
|
1019 |
@param new_data New record
|
|
1020 |
@param dup_key_found Number of duplicate keys found
|
|
1021 |
||
1022 |
@retval 0 Bulk delete used by handler
|
|
1023 |
@retval 1 Bulk delete not used, normal operation used
|
|
1024 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
1025 |
virtual int bulk_update_row(const unsigned char *, unsigned char *, uint32_t *) |
1
by brian
clean slate |
1026 |
{
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
1027 |
assert(false); |
1
by brian
clean slate |
1028 |
return HA_ERR_WRONG_COMMAND; |
1029 |
}
|
|
1030 |
/**
|
|
1031 |
This is called to delete all rows in a table
|
|
1032 |
If the handler don't support this, then this function will
|
|
1033 |
return HA_ERR_WRONG_COMMAND and MySQL will delete the rows one
|
|
1034 |
by one.
|
|
1035 |
*/
|
|
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
1036 |
virtual int delete_all_rows(void) |
1
by brian
clean slate |
1037 |
{ return (my_errno=HA_ERR_WRONG_COMMAND); } |
1038 |
/**
|
|
1039 |
Reset the auto-increment counter to the given value, i.e. the next row
|
|
1040 |
inserted will get the given value. This is called e.g. after TRUNCATE
|
|
1041 |
is emulated by doing a 'DELETE FROM t'. HA_ERR_WRONG_COMMAND is
|
|
1042 |
returned by storage engines that don't support this operation.
|
|
1043 |
*/
|
|
645
by Brian Aker
Cleanup unused attribute |
1044 |
virtual int reset_auto_increment(uint64_t) |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
1045 |
{ return HA_ERR_WRONG_COMMAND; } |
645
by Brian Aker
Cleanup unused attribute |
1046 |
virtual int optimize(Session *, HA_CHECK_OPT *) |
1047 |
{ return HA_ADMIN_NOT_IMPLEMENTED; } |
|
1048 |
virtual int analyze(Session *, HA_CHECK_OPT *) |
|
1049 |
{ return HA_ADMIN_NOT_IMPLEMENTED; } |
|
1050 |
virtual bool check_and_repair(Session *) |
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
1051 |
{ return true; } |
645
by Brian Aker
Cleanup unused attribute |
1052 |
virtual int disable_indexes(uint32_t) |
1053 |
{ return HA_ERR_WRONG_COMMAND; } |
|
1054 |
virtual int enable_indexes(uint32_t) |
|
1055 |
{ return HA_ERR_WRONG_COMMAND; } |
|
1056 |
virtual int discard_or_import_tablespace(bool) |
|
1
by brian
clean slate |
1057 |
{ return (my_errno=HA_ERR_WRONG_COMMAND); } |
53.2.32
by Monty Taylor
First large swath at getting handler stuff clean. |
1058 |
virtual void prepare_for_alter(void) { return; } |
1
by brian
clean slate |
1059 |
virtual void drop_table(const char *name); |
645
by Brian Aker
Cleanup unused attribute |
1060 |
virtual int create(const char *, Table *, HA_CREATE_INFO *)=0; |
1
by brian
clean slate |
1061 |
|
645
by Brian Aker
Cleanup unused attribute |
1062 |
virtual int create_handler_files(const char *, const char *, int, HA_CREATE_INFO *) |
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
1063 |
{ return false; } |
1
by brian
clean slate |
1064 |
};
|
1065 |
||
1066 |
||
1067 |
||
1068 |
/**
|
|
1069 |
A Disk-Sweep MRR interface implementation
|
|
1070 |
||
1071 |
This implementation makes range (and, in the future, 'ref') scans to read
|
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
1072 |
table rows in disk sweeps.
|
1073 |
||
1
by brian
clean slate |
1074 |
Currently it is used by MyISAM and InnoDB. Potentially it can be used with
|
1075 |
any table handler that has non-clustered indexes and on-disk rows.
|
|
1076 |
*/
|
|
1077 |
||
1078 |
class DsMrr_impl |
|
1079 |
{
|
|
1080 |
public: |
|
1081 |
typedef void (handler::*range_check_toggle_func_t)(bool on); |
|
1082 |
||
1083 |
DsMrr_impl() |
|
1084 |
: h2(NULL) {}; |
|
1085 |
||
1086 |
handler *h; /* The "owner" handler object. It is used for scanning the index */ |
|
327.1.5
by Brian Aker
Refactor around classes. TABLE_LIST has been factored out of table.h |
1087 |
Table *table; /* Always equal to h->table */ |
1
by brian
clean slate |
1088 |
private: |
1089 |
/*
|
|
1090 |
Secondary handler object. It is used to retrieve full table rows by
|
|
1091 |
calling rnd_pos().
|
|
1092 |
*/
|
|
1093 |
handler *h2; |
|
1094 |
||
1095 |
/* Buffer to store rowids, or (rowid, range_id) pairs */
|
|
481
by Brian Aker
Remove all of uchar. |
1096 |
unsigned char *rowids_buf; |
1097 |
unsigned char *rowids_buf_cur; /* Current position when reading/writing */ |
|
1098 |
unsigned char *rowids_buf_last; /* When reading: end of used buffer space */ |
|
1099 |
unsigned char *rowids_buf_end; /* End of the buffer */ |
|
1
by brian
clean slate |
1100 |
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
1101 |
bool dsmrr_eof; /* true <=> We have reached EOF when reading index tuples */ |
1
by brian
clean slate |
1102 |
|
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
1103 |
/* true <=> need range association, buffer holds {rowid, range_id} pairs */
|
1
by brian
clean slate |
1104 |
bool is_mrr_assoc; |
1105 |
||
51.1.77
by Jay Pipes
Standardized TRUE/FALSE, removed/replaced DBUG symbols |
1106 |
bool use_default_impl; /* true <=> shortcut all calls to default MRR impl */ |
1
by brian
clean slate |
1107 |
public: |
327.1.5
by Brian Aker
Refactor around classes. TABLE_LIST has been factored out of table.h |
1108 |
void init(handler *h_arg, Table *table_arg) |
1
by brian
clean slate |
1109 |
{
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
1110 |
h= h_arg; |
1
by brian
clean slate |
1111 |
table= table_arg; |
1112 |
}
|
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
1113 |
int dsmrr_init(handler *h, KEY *key, RANGE_SEQ_IF *seq_funcs, |
1114 |
void *seq_init_param, uint32_t n_ranges, uint32_t mode, |
|
1
by brian
clean slate |
1115 |
HANDLER_BUFFER *buf); |
1116 |
void dsmrr_close(); |
|
1117 |
int dsmrr_fill_buffer(handler *h); |
|
1118 |
int dsmrr_next(handler *h, char **range_info); |
|
1119 |
||
482
by Brian Aker
Remove uint. |
1120 |
int dsmrr_info(uint32_t keyno, uint32_t n_ranges, uint32_t keys, uint32_t *bufsz, |
1121 |
uint32_t *flags, COST_VECT *cost); |
|
1
by brian
clean slate |
1122 |
|
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
1123 |
ha_rows dsmrr_info_const(uint32_t keyno, RANGE_SEQ_IF *seq, |
482
by Brian Aker
Remove uint. |
1124 |
void *seq_init_param, uint32_t n_ranges, uint32_t *bufsz, |
1125 |
uint32_t *flags, COST_VECT *cost); |
|
1
by brian
clean slate |
1126 |
private: |
482
by Brian Aker
Remove uint. |
1127 |
bool key_uses_partial_cols(uint32_t keyno); |
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
1128 |
bool choose_mrr_impl(uint32_t keyno, ha_rows rows, uint32_t *flags, uint32_t *bufsz, |
1
by brian
clean slate |
1129 |
COST_VECT *cost); |
660.1.3
by Eric Herman
removed trailing whitespace with simple script: |
1130 |
bool get_disk_sweep_mrr_cost(uint32_t keynr, ha_rows rows, uint32_t flags, |
482
by Brian Aker
Remove uint. |
1131 |
uint32_t *buffer_size, COST_VECT *cost); |
1
by brian
clean slate |
1132 |
};
|
1133 |
||
1134 |
extern const char *ha_row_type[]; |
|
1135 |
extern const char *tx_isolation_names[]; |
|
1136 |
extern const char *binlog_format_names[]; |
|
1137 |
extern TYPELIB tx_isolation_typelib; |
|
1138 |
extern TYPELIB myisam_stats_method_typelib; |
|
61
by Brian Aker
Conversion of handler type. |
1139 |
extern uint32_t total_ha, total_ha_2pc; |
1
by brian
clean slate |
1140 |
|
1141 |
/* Wrapper functions */
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1142 |
#define ha_commit(session) (ha_commit_trans((session), true))
|
1143 |
#define ha_rollback(session) (ha_rollback_trans((session), true))
|
|
1
by brian
clean slate |
1144 |
|
1145 |
/* basic stuff */
|
|
1146 |
int ha_init_errors(void); |
|
1147 |
int ha_init(void); |
|
1148 |
int ha_end(void); |
|
1149 |
int ha_initialize_handlerton(st_plugin_int *plugin); |
|
1150 |
int ha_finalize_handlerton(st_plugin_int *plugin); |
|
1151 |
||
1152 |
TYPELIB *ha_known_exts(void); |
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1153 |
void ha_close_connection(Session* session); |
1
by brian
clean slate |
1154 |
bool ha_flush_logs(handlerton *db_type); |
1155 |
void ha_drop_database(char* path); |
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1156 |
int ha_create_table(Session *session, const char *path, |
1
by brian
clean slate |
1157 |
const char *db, const char *table_name, |
1158 |
HA_CREATE_INFO *create_info, |
|
1159 |
bool update_create_info); |
|
590.1.7
by Stewart Smith
remove mysql_frm_type |
1160 |
int ha_delete_table(Session *session, const char *path, |
1
by brian
clean slate |
1161 |
const char *db, const char *alias, bool generate_warning); |
1162 |
||
1163 |
/* statistics and info */
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1164 |
bool ha_show_status(Session *session, handlerton *db_type, enum ha_stat_type stat); |
1
by brian
clean slate |
1165 |
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1166 |
int ha_find_files(Session *session,const char *db,const char *path, |
1
by brian
clean slate |
1167 |
const char *wild, bool dir, List<LEX_STRING>* files); |
673.3.12
by Stewart Smith
fix RENAME TABLE |
1168 |
int ha_table_exists_in_engine(Session* session, const char* db, const char* name, handlerton **hton= NULL); |
1
by brian
clean slate |
1169 |
|
1170 |
/* key cache */
|
|
1171 |
extern "C" int ha_init_key_cache(const char *name, KEY_CACHE *key_cache); |
|
1172 |
int ha_resize_key_cache(KEY_CACHE *key_cache); |
|
1173 |
int ha_change_key_cache_param(KEY_CACHE *key_cache); |
|
1174 |
int ha_change_key_cache(KEY_CACHE *old_key_cache, KEY_CACHE *new_key_cache); |
|
1175 |
int ha_end_key_cache(KEY_CACHE *key_cache); |
|
1176 |
||
1177 |
/* report to InnoDB that control passes to the client */
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1178 |
int ha_release_temporary_latches(Session *session); |
1
by brian
clean slate |
1179 |
|
1180 |
/* transactions: interface to handlerton functions */
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1181 |
int ha_start_consistent_snapshot(Session *session); |
1
by brian
clean slate |
1182 |
int ha_commit_or_rollback_by_xid(XID *xid, bool commit); |
520.1.22
by Brian Aker
Second pass of thd cleanup |
1183 |
int ha_commit_one_phase(Session *session, bool all); |
1184 |
int ha_rollback_trans(Session *session, bool all); |
|
1185 |
int ha_prepare(Session *session); |
|
1
by brian
clean slate |
1186 |
int ha_recover(HASH *commit_list); |
1187 |
||
1188 |
/* transactions: these functions never call handlerton functions directly */
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1189 |
int ha_commit_trans(Session *session, bool all); |
1190 |
int ha_autocommit_or_rollback(Session *session, int error); |
|
1191 |
int ha_enable_transaction(Session *session, bool on); |
|
1
by brian
clean slate |
1192 |
|
1193 |
/* savepoints */
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1194 |
int ha_rollback_to_savepoint(Session *session, SAVEPOINT *sv); |
1195 |
int ha_savepoint(Session *session, SAVEPOINT *sv); |
|
1196 |
int ha_release_savepoint(Session *session, SAVEPOINT *sv); |
|
1
by brian
clean slate |
1197 |
|
1198 |
/* these are called by storage engines */
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1199 |
void trans_register_ha(Session *session, bool all, handlerton *ht); |
1
by brian
clean slate |
1200 |
|
520.6.7
by Monty Taylor
Moved a bunch of crap out of common_includes. |
1201 |
void table_case_convert(char * name, uint32_t length); |
1202 |
const char *table_case_name(HA_CREATE_INFO *info, const char *name); |
|
1203 |
||
1204 |
extern char reg_ext[FN_EXTLEN]; |
|
1205 |
extern uint32_t reg_ext_length; |
|
1206 |
extern ulong specialflag; |
|
1207 |
extern uint32_t lower_case_table_names; |
|
1208 |
uint32_t filename_to_tablename(const char *from, char *to, uint32_t to_length); |
|
1209 |
uint32_t tablename_to_filename(const char *from, char *to, uint32_t to_length); |
|
1210 |
||
1211 |
||
575.1.3
by Monty Taylor
Moved some stuff out of handler.h. |
1212 |
bool mysql_ha_open(Session *session, TableList *tables, bool reopen); |
1213 |
bool mysql_ha_close(Session *session, TableList *tables); |
|
1214 |
bool mysql_ha_read(Session *, TableList *,enum enum_ha_read_modes,char *, |
|
1215 |
List<Item> *,enum ha_rkey_function,Item *,ha_rows,ha_rows); |
|
1216 |
void mysql_ha_flush(Session *session); |
|
1217 |
void mysql_ha_rm_tables(Session *session, TableList *tables, bool is_locked); |
|
1218 |
void mysql_ha_cleanup(Session *session); |
|
1219 |
||
1
by brian
clean slate |
1220 |
/*
|
1221 |
Storage engine has to assume the transaction will end up with 2pc if
|
|
1222 |
- there is more than one 2pc-capable storage engine available
|
|
1223 |
- in the current transaction 2pc was not disabled yet
|
|
1224 |
*/
|
|
520.1.22
by Brian Aker
Second pass of thd cleanup |
1225 |
#define trans_need_2pc(session, all) ((total_ha_2pc > 1) && \
|
1226 |
!((all ? &session->transaction.all : &session->transaction.stmt)->no_2pc))
|
|
520.6.4
by Monty Taylor
Moved thr_lock.h out of common_includes. |
1227 |
|
575.4.7
by Monty Taylor
More header cleanup. |
1228 |
|
1229 |
bool mysql_xa_recover(Session *session); |
|
1230 |
||
1231 |
SORT_FIELD * make_unireg_sortorder(order_st *order, uint32_t *length, |
|
1232 |
SORT_FIELD *sortorder); |
|
1233 |
int setup_order(Session *session, Item **ref_pointer_array, TableList *tables, |
|
1234 |
List<Item> &fields, List <Item> &all_fields, order_st *order); |
|
1235 |
int setup_group(Session *session, Item **ref_pointer_array, TableList *tables, |
|
1236 |
List<Item> &fields, List<Item> &all_fields, order_st *order, |
|
1237 |
bool *hidden_group_fields); |
|
1238 |
bool fix_inner_refs(Session *session, List<Item> &all_fields, SELECT_LEX *select, |
|
1239 |
Item **ref_pointer_array); |
|
1240 |
||
1241 |
bool handle_select(Session *session, LEX *lex, select_result *result, |
|
1242 |
ulong setup_tables_done_option); |
|
1243 |
bool mysql_select(Session *session, Item ***rref_pointer_array, |
|
1244 |
TableList *tables, uint32_t wild_num, List<Item> &list, |
|
1245 |
COND *conds, uint32_t og_num, order_st *order, order_st *group, |
|
1246 |
Item *having, order_st *proc_param, uint64_t select_type, |
|
1247 |
select_result *result, SELECT_LEX_UNIT *unit, |
|
1248 |
SELECT_LEX *select_lex); |
|
1249 |
void free_underlaid_joins(Session *session, SELECT_LEX *select); |
|
1250 |
bool mysql_explain_union(Session *session, SELECT_LEX_UNIT *unit, |
|
1251 |
select_result *result); |
|
1252 |
int mysql_explain_select(Session *session, SELECT_LEX *sl, char const *type, |
|
1253 |
select_result *result); |
|
1254 |
bool mysql_union(Session *session, LEX *lex, select_result *result, |
|
1255 |
SELECT_LEX_UNIT *unit, ulong setup_tables_done_option); |
|
1256 |
bool mysql_handle_derived(LEX *lex, bool (*processor)(Session *session, |
|
1257 |
LEX *lex, |
|
1258 |
TableList *table)); |
|
1259 |
bool mysql_derived_prepare(Session *session, LEX *lex, TableList *t); |
|
1260 |
bool mysql_derived_filling(Session *session, LEX *lex, TableList *t); |
|
1261 |
void sp_prepare_create_field(Session *session, Create_field *sql_field); |
|
1262 |
int prepare_create_field(Create_field *sql_field, |
|
1263 |
uint32_t *blob_columns, |
|
1264 |
int *timestamps, int *timestamps_with_niladic, |
|
1265 |
int64_t table_flags); |
|
1266 |
bool mysql_create_table(Session *session,const char *db, const char *table_name, |
|
1267 |
HA_CREATE_INFO *create_info, |
|
1268 |
Alter_info *alter_info, |
|
1269 |
bool tmp_table, uint32_t select_field_count); |
|
1270 |
bool mysql_create_table_no_lock(Session *session, const char *db, |
|
1271 |
const char *table_name, |
|
1272 |
HA_CREATE_INFO *create_info, |
|
1273 |
Alter_info *alter_info, |
|
1274 |
bool tmp_table, uint32_t select_field_count, |
|
1275 |
bool lock_open_lock); |
|
1276 |
||
1277 |
bool mysql_alter_table(Session *session, char *new_db, char *new_name, |
|
1278 |
HA_CREATE_INFO *create_info, |
|
1279 |
TableList *table_list, |
|
1280 |
Alter_info *alter_info, |
|
1281 |
uint32_t order_num, order_st *order, bool ignore); |
|
1282 |
bool mysql_recreate_table(Session *session, TableList *table_list); |
|
1283 |
bool mysql_create_like_table(Session *session, TableList *table, |
|
1284 |
TableList *src_table, |
|
1285 |
HA_CREATE_INFO *create_info); |
|
1286 |
bool mysql_rename_table(handlerton *base, const char *old_db, |
|
1287 |
const char * old_name, const char *new_db, |
|
1288 |
const char * new_name, uint32_t flags); |
|
1289 |
bool mysql_prepare_update(Session *session, TableList *table_list, |
|
1290 |
Item **conds, uint32_t order_num, order_st *order); |
|
1291 |
int mysql_update(Session *session,TableList *tables,List<Item> &fields, |
|
1292 |
List<Item> &values,COND *conds, |
|
1293 |
uint32_t order_num, order_st *order, ha_rows limit, |
|
1294 |
enum enum_duplicates handle_duplicates, bool ignore); |
|
1295 |
bool mysql_multi_update(Session *session, TableList *table_list, |
|
1296 |
List<Item> *fields, List<Item> *values, |
|
1297 |
COND *conds, uint64_t options, |
|
1298 |
enum enum_duplicates handle_duplicates, bool ignore, |
|
1299 |
SELECT_LEX_UNIT *unit, SELECT_LEX *select_lex); |
|
1300 |
bool mysql_prepare_insert(Session *session, TableList *table_list, Table *table, |
|
1301 |
List<Item> &fields, List_item *values, |
|
1302 |
List<Item> &update_fields, |
|
1303 |
List<Item> &update_values, enum_duplicates duplic, |
|
1304 |
COND **where, bool select_insert, |
|
1305 |
bool check_fields, bool abort_on_warning); |
|
1306 |
bool mysql_insert(Session *session,TableList *table,List<Item> &fields, |
|
1307 |
List<List_item> &values, List<Item> &update_fields, |
|
1308 |
List<Item> &update_values, enum_duplicates flag, |
|
1309 |
bool ignore); |
|
1310 |
int check_that_all_fields_are_given_values(Session *session, Table *entry, |
|
1311 |
TableList *table_list); |
|
1312 |
void prepare_triggers_for_insert_stmt(Table *table); |
|
1313 |
int mysql_prepare_delete(Session *session, TableList *table_list, Item **conds); |
|
1314 |
bool mysql_delete(Session *session, TableList *table_list, COND *conds, |
|
1315 |
SQL_LIST *order, ha_rows rows, uint64_t options, |
|
1316 |
bool reset_auto_increment); |
|
1317 |
bool mysql_truncate(Session *session, TableList *table_list, bool dont_send_ok); |
|
1318 |
uint32_t create_table_def_key(Session *session, char *key, TableList *table_list, |
|
1319 |
bool tmp_table); |
|
1320 |
TABLE_SHARE *get_table_share(Session *session, TableList *table_list, char *key, |
|
1321 |
uint32_t key_length, uint32_t db_flags, int *error); |
|
1322 |
void release_table_share(TABLE_SHARE *share, enum release_type type); |
|
1323 |
TABLE_SHARE *get_cached_table_share(const char *db, const char *table_name); |
|
1324 |
Table *open_ltable(Session *session, TableList *table_list, thr_lock_type update, |
|
1325 |
uint32_t lock_flags); |
|
1326 |
Table *open_table(Session *session, TableList *table_list, bool *refresh, uint32_t flags); |
|
1327 |
bool name_lock_locked_table(Session *session, TableList *tables); |
|
1328 |
bool reopen_name_locked_table(Session* session, TableList* table_list, bool link_in); |
|
1329 |
Table *table_cache_insert_placeholder(Session *session, const char *key, |
|
1330 |
uint32_t key_length); |
|
1331 |
bool lock_table_name_if_not_cached(Session *session, const char *db, |
|
1332 |
const char *table_name, Table **table); |
|
1333 |
Table *find_locked_table(Session *session, const char *db,const char *table_name); |
|
1334 |
void detach_merge_children(Table *table, bool clear_refs); |
|
1335 |
bool fix_merge_after_open(TableList *old_child_list, TableList **old_last, |
|
1336 |
TableList *new_child_list, TableList **new_last); |
|
1337 |
bool reopen_table(Table *table); |
|
1338 |
bool reopen_tables(Session *session,bool get_locks,bool in_refresh); |
|
1339 |
void close_data_files_and_morph_locks(Session *session, const char *db, |
|
1340 |
const char *table_name); |
|
1341 |
void close_handle_and_leave_table_as_lock(Table *table); |
|
1342 |
bool open_new_frm(Session *session, TABLE_SHARE *share, const char *alias, |
|
1343 |
uint32_t db_stat, uint32_t prgflag, |
|
1344 |
uint32_t ha_open_flags, Table *outparam, |
|
1345 |
TableList *table_desc, MEM_ROOT *mem_root); |
|
1346 |
bool wait_for_tables(Session *session); |
|
1347 |
bool table_is_used(Table *table, bool wait_for_name_lock); |
|
1348 |
Table *drop_locked_tables(Session *session,const char *db, const char *table_name); |
|
1349 |
void abort_locked_tables(Session *session,const char *db, const char *table_name); |
|
1350 |
void execute_init_command(Session *session, sys_var_str *init_command_var, |
|
658
by Brian Aker
Part removal of my_pthread.h |
1351 |
pthread_rwlock_t *var_mutex); |
575.4.7
by Monty Taylor
More header cleanup. |
1352 |
extern Field *not_found_field; |
1353 |
extern Field *view_ref_found; |
|
1354 |
||
1355 |
Field * |
|
1356 |
find_field_in_tables(Session *session, Item_ident *item, |
|
1357 |
TableList *first_table, TableList *last_table, |
|
1358 |
Item **ref, find_item_error_report_type report_error, |
|
1359 |
bool check_privileges, bool register_tree_change); |
|
1360 |
Field * |
|
1361 |
find_field_in_table_ref(Session *session, TableList *table_list, |
|
1362 |
const char *name, uint32_t length, |
|
1363 |
const char *item_name, const char *db_name, |
|
1364 |
const char *table_name, Item **ref, |
|
1365 |
bool check_privileges, bool allow_rowid, |
|
1366 |
uint32_t *cached_field_index_ptr, |
|
1367 |
bool register_tree_change, TableList **actual_table); |
|
1368 |
Field * |
|
1369 |
find_field_in_table(Session *session, Table *table, const char *name, uint32_t length, |
|
1370 |
bool allow_rowid, uint32_t *cached_field_index_ptr); |
|
1371 |
Field * |
|
1372 |
find_field_in_table_sef(Table *table, const char *name); |
|
1373 |
int update_virtual_fields_marked_for_write(Table *table, |
|
1374 |
bool ignore_stored=true); |
|
1375 |
||
1376 |
||
520.6.4
by Monty Taylor
Moved thr_lock.h out of common_includes. |
1377 |
#endif /* DRIZZLED_HANDLER_H */ |