-
Notifications
You must be signed in to change notification settings - Fork 4k
/
Copy pathsql_handler.h
138 lines (103 loc) · 3.58 KB
/
sql_handler.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
/* Copyright (c) 2006, 2015, Oracle and/or its affiliates. All rights reserved.
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; version 2 of the License.
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.
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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
#ifndef SQL_HANDLER_INCLUDED
#define SQL_HANDLER_INCLUDED
#include "my_base.h" /* ha_rkey_function, ha_rows */
#include "sql_cmd.h" // Sql_cmd
#include "sql_lex.h" // enum_ha_read_modes
#include "sql_list.h" /* List */
class THD;
struct TABLE_LIST;
/**
Sql_cmd_handler_open represents HANDLER OPEN statement.
@note Some information about this statement, for example, table to be
opened is still kept in LEX class.
*/
class Sql_cmd_handler_open : public Sql_cmd
{
public:
Sql_cmd_handler_open()
{}
virtual ~Sql_cmd_handler_open()
{}
virtual enum_sql_command sql_command_code() const
{
return SQLCOM_HA_OPEN;
}
virtual bool execute(THD *thd);
};
/**
Sql_cmd_handler_read represents HANDLER READ statement.
@note Some information about this statement, for example, table
list element which identifies HANDLER to be read from,
WHERE and LIMIT clauses is still kept in LEX class.
*/
class Sql_cmd_handler_read : public Sql_cmd
{
public:
Sql_cmd_handler_read(enum_ha_read_modes read_mode,
const char *key_name,
List<Item> *key_expr,
ha_rkey_function rkey_mode)
: m_read_mode(read_mode), m_key_name(key_name), m_key_expr(key_expr),
m_rkey_mode(rkey_mode)
{}
virtual ~Sql_cmd_handler_read()
{}
virtual enum_sql_command sql_command_code() const
{
return SQLCOM_HA_READ;
}
virtual bool execute(THD *thd);
private:
/** Read mode for HANDLER READ: FIRST, NEXT, LAST, ... */
enum enum_ha_read_modes m_read_mode;
/**
Name of key to be used for reading,
NULL in cases when natural row-order is to be used.
*/
const char *m_key_name;
/** Key values to be satisfied. */
List<Item> *m_key_expr;
/** Type of condition for key values to be satisfied. */
enum ha_rkey_function m_rkey_mode;
};
/**
Sql_cmd_handler_close represents HANDLER CLOSE statement.
@note Table list element which identifies HANDLER to be closed
still resides in LEX class.
*/
class Sql_cmd_handler_close : public Sql_cmd
{
public:
Sql_cmd_handler_close()
{}
virtual ~Sql_cmd_handler_close()
{}
virtual enum_sql_command sql_command_code() const
{
return SQLCOM_HA_CLOSE;
}
virtual bool execute(THD *thd);
};
void mysql_ha_flush(THD *thd);
void mysql_ha_flush_tables(THD *thd, TABLE_LIST *all_tables);
void mysql_ha_rm_tables(THD *thd, TABLE_LIST *tables);
void mysql_ha_cleanup(THD *thd);
void mysql_ha_set_explicit_lock_duration(THD *thd);
typedef bool Log_func(THD*, TABLE*, bool,
const uchar*, const uchar*);
int binlog_log_row(TABLE* table,
const uchar *before_record,
const uchar *after_record,
Log_func *log_func);
#endif /* SQL_HANDLER_INCLUDED */