1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2008 Sun Microsystems
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation; version 2 of the License.
10
* This program is distributed in the hope that it will be useful,
11
* but WITHOUT ANY WARRANTY; without even the implied warranty of
12
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
* GNU General Public License for more details.
15
* You should have received a copy of the GNU General Public License
16
* along with this program; if not, write to the Free Software
17
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
#ifndef DRIZZLED_SQL_BASE_H
21
#define DRIZZLED_SQL_BASE_H
23
#include <drizzled/table.h>
28
class Name_resolution_context;
30
void table_cache_free(void);
31
bool table_cache_init(void);
32
uint32_t cached_open_tables(void);
33
uint32_t cached_table_definitions(void);
35
typedef boost::unordered_multimap< TableIdentifier::Key, Table *> TableOpenCache;
36
typedef std::pair< TableOpenCache::const_iterator, TableOpenCache::const_iterator > TableOpenCacheRange;
38
TableOpenCache &get_open_cache();
39
void remove_table(Table *arg);
41
void kill_drizzle(void);
44
void set_item_name(Item *item,char *pos,uint32_t length);
45
bool add_field_to_list(Session *session, LEX_STRING *field_name, enum enum_field_types type,
46
char *length, char *decimal,
47
uint32_t type_modifier,
48
enum column_format_type column_format,
49
Item *default_value, Item *on_update_value,
51
char *change, List<String> *interval_list,
52
const CHARSET_INFO * const cs);
53
CreateField * new_create_field(Session *session, char *field_name, enum_field_types type,
54
char *length, char *decimals,
55
uint32_t type_modifier,
56
Item *default_value, Item *on_update_value,
57
LEX_STRING *comment, char *change,
58
List<String> *interval_list, CHARSET_INFO *cs);
59
void store_position_for_column(const char *name);
60
bool push_new_name_resolution_context(Session *session,
63
void add_join_on(TableList *b,Item *expr);
64
void add_join_natural(TableList *a,TableList *b,List<String> *using_fields,
66
extern Item **not_found_item;
69
A set of constants used for checking non aggregated fields and sum
70
functions mixture in the ONLY_FULL_GROUP_BY_MODE.
72
enum enum_group_by_mode_type
74
NON_AGG_FIELD_USED= 0,
79
This enumeration type is used only by the function find_item_in_list
80
to return the info on how an item has been resolved against a list
81
of possibly aliased items.
82
The item can be resolved:
83
- against an alias name of the list's element (RESOLVED_AGAINST_ALIAS)
84
- against non-aliased field name of the list (RESOLVED_WITH_NO_ALIAS)
85
- against an aliased field name of the list (RESOLVED_BEHIND_ALIAS)
86
- ignoring the alias name in cases when SQL requires to ignore aliases
87
(e.g. when the resolved field reference contains a table name or
88
when the resolved item is an expression) (RESOLVED_IGNORING_ALIAS)
90
enum enum_resolution_type {
92
RESOLVED_IGNORING_ALIAS,
93
RESOLVED_BEHIND_ALIAS,
94
RESOLVED_WITH_NO_ALIAS,
95
RESOLVED_AGAINST_ALIAS
97
Item ** find_item_in_list(Session *session,
98
Item *item, List<Item> &items, uint32_t *counter,
99
find_item_error_report_type report_error,
100
enum_resolution_type *resolution);
101
bool insert_fields(Session *session, Name_resolution_context *context,
102
const char *db_name, const char *table_name,
103
List_iterator<Item> *it, bool any_privileges);
104
bool setup_tables(Session *session, Name_resolution_context *context,
105
List<TableList> *from_clause, TableList *tables,
106
TableList **leaves, bool select_insert);
107
bool setup_tables_and_check_access(Session *session,
108
Name_resolution_context *context,
109
List<TableList> *from_clause,
113
int setup_wild(Session *session, List<Item> &fields,
114
List<Item> *sum_func_list,
116
bool setup_fields(Session *session, Item** ref_pointer_array,
117
List<Item> &item, enum_mark_columns mark_used_columns,
118
List<Item> *sum_func_list, bool allow_sum_func);
119
inline bool setup_fields_with_no_wrap(Session *session, Item **ref_pointer_array,
121
enum_mark_columns mark_used_columns,
122
List<Item> *sum_func_list,
126
res= setup_fields(session, ref_pointer_array, item, mark_used_columns, sum_func_list,
130
int setup_conds(Session *session, TableList *leaves, COND **conds);
131
/* open_and_lock_tables with optional derived handling */
132
TableList *find_table_in_list(TableList *table,
133
TableList *TableList::*link,
135
const char *table_name);
136
TableList *unique_table(TableList *table, TableList *table_list,
137
bool check_alias= false);
138
void remove_db_from_cache(const SchemaIdentifier &schema_identifier);
140
/* bits for last argument to remove_table_from_cache() */
141
#define RTFC_NO_FLAG 0x0000
142
#define RTFC_OWNED_BY_Session_FLAG 0x0001
143
#define RTFC_WAIT_OTHER_THREAD_FLAG 0x0002
144
#define RTFC_CHECK_KILLED_FLAG 0x0004
145
bool remove_table_from_cache(Session *session, TableIdentifier &identifier, uint32_t flags);
147
void mem_alloc_error(size_t size);
149
bool fill_record(Session* session, List<Item> &fields, List<Item> &values, bool ignore_errors= false);
150
bool fill_record(Session *session, Field **field, List<Item> &values, bool ignore_errors= false);
151
inline TableList *find_table_in_global_list(TableList *table,
153
const char *table_name)
155
return find_table_in_list(table, &TableList::next_global,
156
db_name, table_name);
159
} /* namespace drizzled */
161
#endif /* DRIZZLED_SQL_BASE_H */