~drizzle-trunk/drizzle/development

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
 *
1999.6.1 by kalebral at gmail
update Copyright strings to a more common format to help with creating the master debian copyright file
4
 *  Copyright (C) 2008 Sun Microsystems, Inc.
390.1.2 by Monty Taylor
Fixed copyright headers in drizzled/
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
2234 by Brian Aker
Mass removal of ifdef/endif in favor of pragma once.
20
#pragma once
243.1.8 by Jay Pipes
More cleanup and revert broken base.h
21
1 by brian
clean slate
22
/**
23
  @defgroup Semantic_Analysis Semantic Analysis
24
*/
1008.3.17 by Stewart Smith
Start work to construct table proto in parser:
25
#include <drizzled/message/table.pb.h>
2173.2.1 by Monty Taylor
Fixes incorrect usage of include
26
#include <drizzled/name_resolution_context.h>
27
#include <drizzled/table_list.h>
28
#include <drizzled/function/math/real.h>
29
#include <drizzled/key_part_spec.h>
30
#include <drizzled/index_hint.h>
31
#include <drizzled/optimizer/explain_plan.h>
139.1.8 by Stewart Smith
UDFs are now normal Item_func objects. Simplifies handling them a lot.
32
1089.6.3 by Padraig O'Sullivan
Replaced an instance where a uint8_t type was being used to hold a
33
#include <bitset>
1240.7.3 by Padraig O'Sullivan
Used std::string for the type in Select_Lex instead of char *.
34
#include <string>
1089.6.3 by Padraig O'Sullivan
Replaced an instance where a uint8_t type was being used to hold a
35
1 by brian
clean slate
36
/*
37
  The following hack is needed because mysql_yacc.cc does not define
38
  YYSTYPE before including this file
39
*/
40
722.1.4 by Monty Taylor
Removed all the setting of DEFS everywhere. Use configmake.h to get the values
41
#ifdef DRIZZLE_SERVER
1878.3.1 by Monty Taylor
Split set_var.* into sys_var.* and set_var.*
42
/* set_var should change to set_var here ... */
43
# include <drizzled/sys_var.h>
722.1.4 by Monty Taylor
Removed all the setting of DEFS everywhere. Use configmake.h to get the values
44
# include <drizzled/item/func.h>
45
# ifdef DRIZZLE_YACC
46
#  define LEX_YYSTYPE void *
47
# else
48
#  if defined(DRIZZLE_LEX)
1237.9.4 by Padraig O'Sullivan
Removed the inclusion of drizzled/field.h in the server_includes header file.
49
#   include <drizzled/foreign_key.h>
722.1.4 by Monty Taylor
Removed all the setting of DEFS everywhere. Use configmake.h to get the values
50
#   include <drizzled/lex_symbol.h>
2227.4.3 by Olaf van der Spek
Remove unnecessary statement.h include
51
#   include <drizzled/comp_creator.h>
722.1.4 by Monty Taylor
Removed all the setting of DEFS everywhere. Use configmake.h to get the values
52
#   include <drizzled/sql_yacc.h>
53
#   define LEX_YYSTYPE YYSTYPE *
54
#  else
55
#   define LEX_YYSTYPE void *
56
#  endif /* defined(DRIZZLE_LEX) */
57
# endif /* DRIZZLE_YACC */
58
#endif /* DRIZZLE_SERVER */
1 by brian
clean slate
59
60
// describe/explain types
61
#define DESCRIBE_NORMAL		1
62
#define DESCRIBE_EXTENDED	2
63
319.1.1 by Grant Limberg
renamed all instances of MYSQL_ to DRIZZLE_
64
#ifdef DRIZZLE_SERVER
1 by brian
clean slate
65
66
#define DERIVED_NONE	0
67
#define DERIVED_SUBQUERY	1
68
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
69
namespace drizzled
70
{
71
1 by brian
clean slate
72
typedef List<Item> List_item;
73
74
enum sub_select_type
75
{
1027 by Brian Aker
Merge Jay
76
  UNSPECIFIED_TYPE,
77
  UNION_TYPE,
78
  INTERSECT_TYPE,
79
  EXCEPT_TYPE,
80
  GLOBAL_OPTIONS_TYPE,
81
  DERIVED_TABLE_TYPE,
82
  OLAP_TYPE
1 by brian
clean slate
83
};
84
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
85
enum olap_type
1 by brian
clean slate
86
{
1027 by Brian Aker
Merge Jay
87
  UNSPECIFIED_OLAP_TYPE,
88
  CUBE_TYPE,
89
  ROLLUP_TYPE
1 by brian
clean slate
90
};
91
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
92
/*
93
  The state of the lex parsing for selects
94
1 by brian
clean slate
95
   master and slaves are pointers to select_lex.
96
   master is pointer to upper level node.
97
   slave is pointer to lower level node
98
   select_lex is a SELECT without union
99
   unit is container of either
100
     - One SELECT
101
     - UNION of selects
102
   select_lex and unit are both inherited form select_lex_node
103
   neighbors are two select_lex or units on the same level
104
105
   All select describing structures linked with following pointers:
106
   - list of neighbors (next/prev) (prev of first element point to slave
107
     pointer of upper structure)
108
     - For select this is a list of UNION's (or one element list)
109
     - For units this is a list of sub queries for the upper level select
110
111
   - pointer to master (master), which is
112
     If this is a unit
113
       - pointer to outer select_lex
114
     If this is a select_lex
115
       - pointer to outer unit structure for select
116
117
   - pointer to slave (slave), which is either:
118
     If this is a unit:
119
       - first SELECT that belong to this unit
120
     If this is a select_lex
121
       - first unit that belong to this SELECT (subquries or derived tables)
122
123
   - list of all select_lex (link_next/link_prev)
124
     This is to be used for things like derived tables creation, where we
125
     go through this list and create the derived tables.
126
127
   If unit contain several selects (UNION now, INTERSECT etc later)
128
   then it have special select_lex called fake_select_lex. It used for
129
   storing global parameters (like ORDER BY, LIMIT) and executing union.
130
   Subqueries used in global ORDER BY clause will be attached to this
131
   fake_select_lex, which will allow them correctly resolve fields of
132
   'upper' UNION and outer selects.
133
134
   For example for following query:
135
136
   select *
137
     from table1
138
     where table1.field IN (select * from table1_1_1 union
139
                            select * from table1_1_2)
140
     union
141
   select *
142
     from table2
143
     where table2.field=(select (select f1 from table2_1_1_1_1
144
                                   where table2_1_1_1_1.f2=table2_1_1.f3)
145
                           from table2_1_1
146
                           where table2_1_1.f1=table2.f2)
147
     union
148
   select * from table3;
149
150
   we will have following structure:
151
152
   select1: (select * from table1 ...)
153
   select2: (select * from table2 ...)
154
   select3: (select * from table3)
155
   select1.1.1: (select * from table1_1_1)
156
   ...
157
158
     main unit
159
     fake0
160
     select1 select2 select3
161
     |^^     |^
162
    s|||     ||master
163
    l|||     |+---------------------------------+
164
    a|||     +---------------------------------+|
165
    v|||master                         slave   ||
166
    e||+-------------------------+             ||
167
     V|            neighbor      |             V|
168
     unit1.1<+==================>unit1.2       unit2.1
169
     fake1.1
170
     select1.1.1 select 1.1.2    select1.2.1   select2.1.1
171
                                               |^
172
                                               ||
173
                                               V|
174
                                               unit2.1.1.1
175
                                               select2.1.1.1.1
176
177
178
   relation in main unit will be following:
179
   (bigger picture for:
180
      main unit
181
      fake0
182
      select1 select2 select3
183
   in the above picture)
184
185
         main unit
186
         |^^^^|fake_select_lex
187
         |||||+--------------------------------------------+
188
         ||||+--------------------------------------------+|
189
         |||+------------------------------+              ||
190
         ||+--------------+                |              ||
191
    slave||master         |                |              ||
192
         V|      neighbor |       neighbor |        master|V
193
         select1<========>select2<========>select3        fake0
194
195
    list of all select_lex will be following (as it will be constructed by
196
    parser):
197
198
    select1->select2->select3->select2.1.1->select 2.1.2->select2.1.1.1.1-+
199
                                                                          |
200
    +---------------------------------------------------------------------+
201
    |
202
    +->select1.1.1->select1.1.2
203
204
*/
205
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
206
/*
846 by Brian Aker
Removing on typedeffed class.
207
    Base class for Select_Lex (Select_Lex) &
848 by Brian Aker
typdef class removal (just... use the name of the class).
208
    Select_Lex_Unit (Select_Lex_Unit)
1 by brian
clean slate
209
*/
847 by Brian Aker
More typdef class removal.
210
class Select_Lex_Node {
1 by brian
clean slate
211
protected:
847 by Brian Aker
More typdef class removal.
212
  Select_Lex_Node *next, **prev,   /* neighbor list */
1 by brian
clean slate
213
    *master, *slave,                  /* vertical links */
846 by Brian Aker
Removing on typedeffed class.
214
    *link_next, **link_prev;          /* list of whole Select_Lex */
1 by brian
clean slate
215
public:
216
151 by Brian Aker
Ulonglong to uint64_t
217
  uint64_t options;
1 by brian
clean slate
218
219
  /*
220
    result of this query can't be cached, bit field, can be :
221
      UNCACHEABLE_DEPENDENT
222
      UNCACHEABLE_RAND
223
      UNCACHEABLE_SIDEEFFECT
224
      UNCACHEABLE_EXPLAIN
225
      UNCACHEABLE_PREPARE
226
  */
1858.1.1 by Padraig O'Sullivan
Replaced a uint8_t member with a standard bitset since it was being used as a bitset....
227
  std::bitset<8> uncacheable;
2227.4.13 by Olaf van der Spek
Refactor Session
228
  sub_select_type linkage;
1 by brian
clean slate
229
  bool no_table_names_allowed; /* used for global order by */
230
  bool no_error; /* suppress error message (convert it to warnings) */
231
232
  static void *operator new(size_t size)
233
  {
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
234
    return memory::sql_alloc(size);
1 by brian
clean slate
235
  }
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
236
  static void *operator new(size_t size, memory::Root *mem_root)
2318.6.41 by Olaf van der Spek
Refactor
237
  { return mem_root->alloc(size); }
2318.6.40 by Olaf van der Spek
Refactor
238
  static void operator delete(void*, size_t)
1241.9.57 by Monty Taylor
Oy. Bigger change than I normally like - but this stuff is all intertwined.
239
  {  }
2318.6.40 by Olaf van der Spek
Refactor
240
  static void operator delete(void*, memory::Root*)
77.1.7 by Monty Taylor
Heap builds clean.
241
  {}
847 by Brian Aker
More typdef class removal.
242
  Select_Lex_Node(): linkage(UNSPECIFIED_TYPE) {}
243
  virtual ~Select_Lex_Node() {}
244
  inline Select_Lex_Node* get_master() { return master; }
1 by brian
clean slate
245
  virtual void init_query();
246
  virtual void init_select();
847 by Brian Aker
More typdef class removal.
247
  void include_down(Select_Lex_Node *upper);
248
  void include_neighbour(Select_Lex_Node *before);
249
  void include_standalone(Select_Lex_Node *sel, Select_Lex_Node **ref);
250
  void include_global(Select_Lex_Node **plink);
1 by brian
clean slate
251
  void exclude();
252
848 by Brian Aker
typdef class removal (just... use the name of the class).
253
  virtual Select_Lex_Unit* master_unit()= 0;
846 by Brian Aker
Removing on typedeffed class.
254
  virtual Select_Lex* outer_select()= 0;
255
  virtual Select_Lex* return_after_parsing()= 0;
1 by brian
clean slate
256
257
  virtual bool set_braces(bool value);
258
  virtual bool inc_in_sum_expr();
202 by Brian Aker
Cleanup sql_lex to modern types.
259
  virtual uint32_t get_in_sum_expr();
327.2.4 by Brian Aker
Refactoring table.h
260
  virtual TableList* get_table_list();
1 by brian
clean slate
261
  virtual List<Item>* get_item_list();
520.1.22 by Brian Aker
Second pass of thd cleanup
262
  virtual TableList *add_table_to_list(Session *session, Table_ident *table,
2371.1.2 by Brian Aker
Remove the typedef on lexkey
263
                                       lex_string_t *alias,
1858.1.2 by Padraig O'Sullivan
Converted another uint8_t type to be a bitset.
264
                                       const std::bitset<NUM_OF_TABLE_OPTIONS>& table_options,
265
                                       thr_lock_type flags= TL_UNLOCK,
266
                                       List<Index_hint> *hints= 0,
2371.1.2 by Brian Aker
Remove the typedef on lexkey
267
                                       lex_string_t *option= 0);
644 by Brian Aker
Clean up warnings for Solaris.
268
  virtual void set_lock_for_tables(thr_lock_type)
77.1.7 by Monty Taylor
Heap builds clean.
269
  {}
1 by brian
clean slate
270
848 by Brian Aker
typdef class removal (just... use the name of the class).
271
  friend class Select_Lex_Unit;
2026.2.1 by Monty Taylor
Renamed things prefixed mysql_ or mysqld_
272
  friend bool new_select(LEX *lex, bool move_down);
1 by brian
clean slate
273
private:
274
  void fast_exclude();
275
};
276
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
277
/*
848 by Brian Aker
typdef class removal (just... use the name of the class).
278
   Select_Lex_Unit - unit of selects (UNION, INTERSECT, ...) group
846 by Brian Aker
Removing on typedeffed class.
279
   Select_Lexs
1 by brian
clean slate
280
*/
848 by Brian Aker
typdef class removal (just... use the name of the class).
281
class Select_Lex_Unit: public Select_Lex_Node {
1 by brian
clean slate
282
protected:
327.2.4 by Brian Aker
Refactoring table.h
283
  TableList result_table_list;
1 by brian
clean slate
284
  select_union *union_result;
327.1.5 by Brian Aker
Refactor around classes. TABLE_LIST has been factored out of table.h
285
  Table *table; /* temporary table using for appending UNION results */
1 by brian
clean slate
286
287
  select_result *result;
151 by Brian Aker
Ulonglong to uint64_t
288
  uint64_t found_rows_for_union;
1 by brian
clean slate
289
  bool saved_error;
290
291
public:
292
  bool  prepared, // prepare phase already performed for UNION (unit)
293
    optimized, // optimize phase already performed for UNION (unit)
294
    executed, // already executed
295
    cleaned;
296
297
  // list of fields which points to temporary table for union
298
  List<Item> item_list;
299
  /*
300
    list of types of items inside union (used for union & derived tables)
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
301
1 by brian
clean slate
302
    Item_type_holders from which this list consist may have pointers to Field,
303
    pointers is valid only after preparing SELECTS of this unit and before
304
    any SELECT of this unit execution
305
306
    TODO:
307
    Possibly this member should be protected, and its direct use replaced
308
    by get_unit_column_types(). Check the places where it is used.
309
  */
310
  List<Item> types;
311
  /*
312
    Pointer to 'last' select or pointer to unit where stored
313
    global parameters for union
314
  */
846 by Brian Aker
Removing on typedeffed class.
315
  Select_Lex *global_parameters;
1 by brian
clean slate
316
  //node on wich we should return current_select pointer after parsing subquery
846 by Brian Aker
Removing on typedeffed class.
317
  Select_Lex *return_to;
1 by brian
clean slate
318
  /* LIMIT clause runtime counters */
319
  ha_rows select_limit_cnt, offset_limit_cnt;
320
  /* not NULL if unit used in subselect, point to subselect item */
321
  Item_subselect *item;
322
  /* thread handler */
520.1.22 by Brian Aker
Second pass of thd cleanup
323
  Session *session;
1 by brian
clean slate
324
  /*
846 by Brian Aker
Removing on typedeffed class.
325
    Select_Lex for hidden SELECT in onion which process global
1 by brian
clean slate
326
    ORDER BY and LIMIT
327
  */
846 by Brian Aker
Removing on typedeffed class.
328
  Select_Lex *fake_select_lex;
1 by brian
clean slate
329
846 by Brian Aker
Removing on typedeffed class.
330
  Select_Lex *union_distinct; /* pointer to the last UNION DISTINCT */
1 by brian
clean slate
331
  bool describe; /* union exec() called for EXPLAIN */
332
333
  void init_query();
848 by Brian Aker
typdef class removal (just... use the name of the class).
334
  Select_Lex_Unit* master_unit();
846 by Brian Aker
Removing on typedeffed class.
335
  Select_Lex* outer_select();
336
  Select_Lex* first_select()
337
  {
338
    return reinterpret_cast<Select_Lex*>(slave);
339
  }
848 by Brian Aker
typdef class removal (just... use the name of the class).
340
  Select_Lex_Unit* next_unit()
846 by Brian Aker
Removing on typedeffed class.
341
  {
848 by Brian Aker
typdef class removal (just... use the name of the class).
342
    return reinterpret_cast<Select_Lex_Unit*>(next);
846 by Brian Aker
Removing on typedeffed class.
343
  }
344
  Select_Lex* return_after_parsing() { return return_to; }
1 by brian
clean slate
345
  void exclude_level();
346
  void exclude_tree();
347
348
  /* UNION methods */
892.2.4 by Monty Taylor
Fixed more warnings.
349
  bool prepare(Session *session, select_result *result,
350
               uint64_t additional_options);
1 by brian
clean slate
351
  bool exec();
352
  bool cleanup();
353
  inline void unclean() { cleaned= 0; }
354
  void reinit_exec_mechanism();
355
2215.2.1 by Stewart Smith
remove enum_query_type which was effectively unused. It was set to one value once, compared to it once (i.e. always true) and passed around everywhere doing nothing.
356
  void print(String *str);
1 by brian
clean slate
357
520.1.22 by Brian Aker
Second pass of thd cleanup
358
  bool add_fake_select_lex(Session *session);
359
  void init_prepare_fake_select_lex(Session *session);
1 by brian
clean slate
360
  bool change_result(select_result_interceptor *result,
361
                     select_result_interceptor *old_result);
846 by Brian Aker
Removing on typedeffed class.
362
  void set_limit(Select_Lex *values);
520.1.22 by Brian Aker
Second pass of thd cleanup
363
  void set_session(Session *session_arg) { session= session_arg; }
2385.3.18 by Olaf van der Spek
Refactor
364
  inline bool is_union();
1 by brian
clean slate
365
2385.3.18 by Olaf van der Spek
Refactor
366
  friend void lex_start(Session*);
1 by brian
clean slate
367
368
  List<Item> *get_unit_column_types();
369
};
370
371
/*
846 by Brian Aker
Removing on typedeffed class.
372
  Select_Lex - store information of parsed SELECT statment
1 by brian
clean slate
373
*/
2385.3.18 by Olaf van der Spek
Refactor
374
class Select_Lex : public Select_Lex_Node
1 by brian
clean slate
375
{
376
public:
1889.1.3 by Brian Aker
Merge in additional C++ warning fixes.
377
378
  Select_Lex() :
379
    context(),
380
    db(0),
381
    where(0),
382
    having(0),
383
    cond_value(),
384
    having_value(),
385
    parent_lex(0),
386
    olap(UNSPECIFIED_OLAP_TYPE),
387
    table_list(),
388
    group_list(),
389
    item_list(),
390
    interval_list(),
391
    is_item_list_lookup(false),
392
    join(0),
393
    top_join_list(),
394
    join_list(0),
395
    embedding(0),
396
    sj_nests(),
397
    leaf_tables(0),
398
    type(optimizer::ST_PRIMARY),
399
    order_list(),
400
    gorder_list(0),
401
    select_limit(0),
402
    offset_limit(0),
403
    ref_pointer_array(0),
404
    select_n_having_items(0),
405
    cond_count(0),
406
    between_count(0),
407
    max_equal_elems(0),
408
    select_n_where_fields(0),
409
    parsing_place(NO_MATTER),
410
    with_sum_func(0),
411
    in_sum_expr(0),
412
    select_number(0),
413
    nest_level(0),
414
    inner_sum_func_list(0),
415
    with_wild(0),
416
    braces(0),
417
    having_fix_field(0),
418
    inner_refs_list(),
419
    n_sum_items(0),
420
    n_child_sum_items(0),
421
    explicit_limit(0),
2141.4.2 by Andrew Hutchings
Implicit joins of the form "SELECT * FROM t1, t2" without WHERE or ON now error.
422
    is_cross(false),
1889.1.3 by Brian Aker
Merge in additional C++ warning fixes.
423
    subquery_in_having(0),
424
    is_correlated(0),
425
    exclude_from_table_unique_test(0),
426
    non_agg_fields(),
427
    cur_pos_in_select_list(0),
428
    prev_join_using(0),
429
    full_group_by_flag(),
430
    current_index_hint_type(INDEX_HINT_IGNORE),
431
    current_index_hint_clause(),
432
    index_hints(0)
433
  {
434
  }
435
1 by brian
clean slate
436
  Name_resolution_context context;
2430.1.9 by Olaf van der Spek
Add const
437
  const char *db;
1014.4.9 by Jay Pipes
Code style cleanup and removal of dead LEX_SERVER_OPTIONS struct
438
  /* An Item representing the WHERE clause */
439
  Item *where;
440
  /* An Item representing the HAVING clause */
441
  Item *having;
1 by brian
clean slate
442
  /* Saved values of the WHERE and HAVING clauses*/
1014.4.9 by Jay Pipes
Code style cleanup and removal of dead LEX_SERVER_OPTIONS struct
443
  Item::cond_result cond_value;
444
  Item::cond_result having_value;
1 by brian
clean slate
445
  /* point on lex in which it was created, used in view subquery detection */
575.4.7 by Monty Taylor
More header cleanup.
446
  LEX *parent_lex;
2227.4.13 by Olaf van der Spek
Refactor Session
447
  olap_type olap;
327.2.4 by Brian Aker
Refactoring table.h
448
  /* FROM clause - points to the beginning of the TableList::next_local list. */
1014.4.9 by Jay Pipes
Code style cleanup and removal of dead LEX_SERVER_OPTIONS struct
449
  SQL_LIST table_list;
450
  SQL_LIST group_list; /* GROUP BY clause. */
451
  List<Item> item_list;  /* list of fields & expressions */
452
  List<String> interval_list;
453
  bool is_item_list_lookup;
1541.1.1 by Brian Aker
JOIN -> Join rename
454
  Join *join; /* after Join::prepare it is pointer to corresponding JOIN */
327.2.4 by Brian Aker
Refactoring table.h
455
  List<TableList> top_join_list; /* join list of the top level          */
456
  List<TableList> *join_list;    /* list for the currently parsed join  */
457
  TableList *embedding;          /* table embedding to the above list   */
458
  List<TableList> sj_nests;
1 by brian
clean slate
459
  /*
460
    Beginning of the list of leaves in a FROM clause, where the leaves
461
    inlcude all base tables including view tables. The tables are connected
327.2.4 by Brian Aker
Refactoring table.h
462
    by TableList::next_leaf, so leaf_tables points to the left-most leaf.
1 by brian
clean slate
463
  */
327.2.4 by Brian Aker
Refactoring table.h
464
  TableList *leaf_tables;
2227.4.13 by Olaf van der Spek
Refactor Session
465
  drizzled::optimizer::select_type type; /* type of select for EXPLAIN */
1 by brian
clean slate
466
467
  SQL_LIST order_list;                /* ORDER clause */
468
  SQL_LIST *gorder_list;
469
  Item *select_limit, *offset_limit;  /* LIMIT clause parameters */
1014.4.9 by Jay Pipes
Code style cleanup and removal of dead LEX_SERVER_OPTIONS struct
470
  /* Arrays of pointers to top elements of all_fields list */
1 by brian
clean slate
471
  Item **ref_pointer_array;
472
473
  /*
474
    number of items in select_list and HAVING clause used to get number
475
    bigger then can be number of entries that will be added to all item
476
    list during split_sum_func
477
  */
202 by Brian Aker
Cleanup sql_lex to modern types.
478
  uint32_t select_n_having_items;
479
  uint32_t cond_count;    /* number of arguments of and/or/xor in where/having/on */
480
  uint32_t between_count; /* number of between predicates in where/having/on      */
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
481
  uint32_t max_equal_elems; /* maximal number of elements in multiple equalities  */
1 by brian
clean slate
482
  /*
483
    Number of fields used in select list or where clause of current select
484
    and all inner subselects.
485
  */
202 by Brian Aker
Cleanup sql_lex to modern types.
486
  uint32_t select_n_where_fields;
1 by brian
clean slate
487
  enum_parsing_place parsing_place; /* where we are parsing expression */
488
  bool with_sum_func;   /* sum function indicator */
489
202 by Brian Aker
Cleanup sql_lex to modern types.
490
  uint32_t in_sum_expr;
491
  uint32_t select_number; /* number of select (used for EXPLAIN) */
937.2.6 by Stewart Smith
make set_if_bigger typesafe for C and C++. Fix up everywhere.
492
  int8_t nest_level;     /* nesting level of select */
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
493
  Item_sum *inner_sum_func_list; /* list of sum func in nested selects */
202 by Brian Aker
Cleanup sql_lex to modern types.
494
  uint32_t with_wild; /* item list contain '*' */
1014.4.9 by Jay Pipes
Code style cleanup and removal of dead LEX_SERVER_OPTIONS struct
495
  bool braces;   	/* SELECT ... UNION (SELECT ... ) <- this braces */
51.1.52 by Jay Pipes
Removed/replaced DBUG symbols and standardized TRUE/FALSE
496
  /* true when having fix field called in processing of this SELECT */
1 by brian
clean slate
497
  bool having_fix_field;
498
  /* List of references to fields referenced from inner selects */
499
  List<Item_outer_ref> inner_refs_list;
500
  /* Number of Item_sum-derived objects in this SELECT */
202 by Brian Aker
Cleanup sql_lex to modern types.
501
  uint32_t n_sum_items;
1 by brian
clean slate
502
  /* Number of Item_sum-derived objects in children and descendant SELECTs */
202 by Brian Aker
Cleanup sql_lex to modern types.
503
  uint32_t n_child_sum_items;
1 by brian
clean slate
504
505
  /* explicit LIMIT clause was used */
506
  bool explicit_limit;
2141.4.2 by Andrew Hutchings
Implicit joins of the form "SELECT * FROM t1, t2" without WHERE or ON now error.
507
508
  /* explicit CROSS JOIN was used */
509
  bool is_cross;
510
1 by brian
clean slate
511
  /*
512
    there are subquery in HAVING clause => we can't close tables before
513
    query processing end even if we use temporary table
514
  */
515
  bool subquery_in_having;
51.1.52 by Jay Pipes
Removed/replaced DBUG symbols and standardized TRUE/FALSE
516
  /* true <=> this SELECT is correlated w.r.t. some ancestor select */
1 by brian
clean slate
517
  bool is_correlated;
518
  /* exclude this select from check of unique_table() */
519
  bool exclude_from_table_unique_test;
520
  /* List of fields that aren't under an aggregate function */
521
  List<Item_field> non_agg_fields;
522
  /* index in the select list of the expression currently being fixed */
523
  int cur_pos_in_select_list;
524
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
525
  /*
1 by brian
clean slate
526
    This is a copy of the original JOIN USING list that comes from
527
    the parser. The parser :
327.2.4 by Brian Aker
Refactoring table.h
528
      1. Sets the natural_join of the second TableList in the join
846 by Brian Aker
Removing on typedeffed class.
529
         and the Select_Lex::prev_join_using.
327.2.4 by Brian Aker
Refactoring table.h
530
      2. Makes a parent TableList and sets its is_natural_join/
1 by brian
clean slate
531
       join_using_fields members.
327.2.4 by Brian Aker
Refactoring table.h
532
      3. Uses the wrapper TableList as a table in the upper level.
1 by brian
clean slate
533
    We cannot assign directly to join_using_fields in the parser because
327.2.4 by Brian Aker
Refactoring table.h
534
    at stage (1.) the parent TableList is not constructed yet and
1 by brian
clean slate
535
    the assignment will override the JOIN USING fields of the lower level
536
    joins on the right.
537
  */
538
  List<String> *prev_join_using;
539
  /*
540
    Bitmap used in the ONLY_FULL_GROUP_BY_MODE to prevent mixture of aggregate
541
    functions and non aggregated fields when GROUP BY list is absent.
542
    Bits:
543
      0 - non aggregated fields are used in this select,
544
          defined as NON_AGG_FIELD_USED.
545
      1 - aggregate functions are used in this select,
546
          defined as SUM_FUNC_USED.
547
  */
1089.6.3 by Padraig O'Sullivan
Replaced an instance where a uint8_t type was being used to hold a
548
  std::bitset<2> full_group_by_flag;
1637.1.3 by Brian Aker
This fixes the parser to no longer do the bad syntax around the cross join
549
1 by brian
clean slate
550
  void init_query();
551
  void init_select();
848 by Brian Aker
typdef class removal (just... use the name of the class).
552
  Select_Lex_Unit* master_unit();
553
  Select_Lex_Unit* first_inner_unit()
846 by Brian Aker
Removing on typedeffed class.
554
  {
848 by Brian Aker
typdef class removal (just... use the name of the class).
555
    return (Select_Lex_Unit*) slave;
846 by Brian Aker
Removing on typedeffed class.
556
  }
557
  Select_Lex* outer_select();
1014.4.9 by Jay Pipes
Code style cleanup and removal of dead LEX_SERVER_OPTIONS struct
558
  Select_Lex* next_select()
559
  {
560
    return (Select_Lex*) next;
561
  }
846 by Brian Aker
Removing on typedeffed class.
562
  Select_Lex* next_select_in_list()
563
  {
564
    return (Select_Lex*) link_next;
565
  }
847 by Brian Aker
More typdef class removal.
566
  Select_Lex_Node** next_select_in_list_addr()
1 by brian
clean slate
567
  {
568
    return &link_next;
569
  }
846 by Brian Aker
Removing on typedeffed class.
570
  Select_Lex* return_after_parsing()
1 by brian
clean slate
571
  {
572
    return master_unit()->return_after_parsing();
573
  }
574
846 by Brian Aker
Removing on typedeffed class.
575
  void mark_as_dependent(Select_Lex *last);
1 by brian
clean slate
576
577
  bool set_braces(bool value);
578
  bool inc_in_sum_expr();
202 by Brian Aker
Cleanup sql_lex to modern types.
579
  uint32_t get_in_sum_expr();
1 by brian
clean slate
580
2318.6.31 by Olaf van der Spek
Refactor
581
  void add_item_to_list(Session *session, Item *item);
582
  void add_group_to_list(Session *session, Item *item, bool asc);
2318.6.30 by Olaf van der Spek
Refactor
583
  void add_order_to_list(Session *session, Item *item, bool asc);
1027 by Brian Aker
Merge Jay
584
  TableList* add_table_to_list(Session *session,
585
                               Table_ident *table,
2371.1.2 by Brian Aker
Remove the typedef on lexkey
586
                               lex_string_t *alias,
1858.1.2 by Padraig O'Sullivan
Converted another uint8_t type to be a bitset.
587
                               const std::bitset<NUM_OF_TABLE_OPTIONS>& table_options,
1027 by Brian Aker
Merge Jay
588
                               thr_lock_type flags= TL_UNLOCK,
589
                               List<Index_hint> *hints= 0,
2371.1.2 by Brian Aker
Remove the typedef on lexkey
590
                               lex_string_t *option= 0);
327.2.4 by Brian Aker
Refactoring table.h
591
  TableList* get_table_list();
2318.6.26 by Olaf van der Spek
Refactor
592
  void init_nested_join(Session&);
520.1.22 by Brian Aker
Second pass of thd cleanup
593
  TableList *end_nested_join(Session *session);
594
  TableList *nest_last_join(Session *session);
327.2.4 by Brian Aker
Refactoring table.h
595
  void add_joined_table(TableList *table);
596
  TableList *convert_right_join();
1 by brian
clean slate
597
  List<Item>* get_item_list();
598
  void set_lock_for_tables(thr_lock_type lock_type);
599
  inline void init_order()
600
  {
601
    order_list.elements= 0;
602
    order_list.first= 0;
481 by Brian Aker
Remove all of uchar.
603
    order_list.next= (unsigned char**) &order_list.first;
1 by brian
clean slate
604
  }
605
  /*
2026.2.1 by Monty Taylor
Renamed things prefixed mysql_ or mysqld_
606
    This method created for reiniting LEX in admin_table() and can be
846 by Brian Aker
Removing on typedeffed class.
607
    used only if you are going remove all Select_Lex & units except belonger
1 by brian
clean slate
608
    to LEX (LEX::unit & LEX::select, for other purposes there are
848 by Brian Aker
typdef class removal (just... use the name of the class).
609
    Select_Lex_Unit::exclude_level & Select_Lex_Unit::exclude_tree
1 by brian
clean slate
610
  */
1014.4.9 by Jay Pipes
Code style cleanup and removal of dead LEX_SERVER_OPTIONS struct
611
  void cut_subtree()
612
  {
613
    slave= 0;
614
  }
1 by brian
clean slate
615
  bool test_limit();
616
2385.3.18 by Olaf van der Spek
Refactor
617
  friend void lex_start(Session*);
1 by brian
clean slate
618
  void make_empty_select()
619
  {
620
    init_query();
621
    init_select();
622
  }
2318.6.31 by Olaf van der Spek
Refactor
623
  void setup_ref_array(Session *session, uint32_t order_group_num);
2215.2.1 by Stewart Smith
remove enum_query_type which was effectively unused. It was set to one value once, compared to it once (i.e. always true) and passed around everywhere doing nothing.
624
  void print(Session *session, String *str);
625
  static void print_order(String *str, Order *order);
626
627
  void print_limit(Session *session, String *str);
520.1.22 by Brian Aker
Second pass of thd cleanup
628
  void fix_prepare_information(Session *session, Item **conds, Item **having_conds);
1 by brian
clean slate
629
  /*
630
    Destroy the used execution plan (JOIN) of this subtree (this
848 by Brian Aker
typdef class removal (just... use the name of the class).
631
    Select_Lex and all nested Select_Lexes and Select_Lex_Units).
1 by brian
clean slate
632
  */
633
  bool cleanup();
634
  /*
635
    Recursively cleanup the join of this select lex and of all nested
636
    select lexes.
637
  */
638
  void cleanup_all_joins(bool full);
639
2227.4.13 by Olaf van der Spek
Refactor Session
640
  void set_index_hint_type(index_hint_type type, index_clause_map clause);
1 by brian
clean slate
641
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
642
  /*
1 by brian
clean slate
643
   Add a index hint to the tagged list of hints. The type and clause of the
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
644
   hint will be the current ones (set by set_index_hint())
1 by brian
clean slate
645
  */
2385.3.21 by Olaf van der Spek
Refactor
646
  void add_index_hint(Session*, const char*);
1 by brian
clean slate
647
648
  /* make a list to hold index hints */
520.1.22 by Brian Aker
Second pass of thd cleanup
649
  void alloc_index_hints (Session *session);
1 by brian
clean slate
650
  /* read and clear the index hints */
2385.3.18 by Olaf van der Spek
Refactor
651
  List<Index_hint>* pop_index_hints()
1 by brian
clean slate
652
  {
653
    List<Index_hint> *hints= index_hints;
654
    index_hints= NULL;
655
    return hints;
656
  }
657
2385.3.18 by Olaf van der Spek
Refactor
658
  void clear_index_hints() { index_hints= NULL; }
1 by brian
clean slate
659
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
660
private:
1 by brian
clean slate
661
  /* current index hint kind. used in filling up index_hints */
2227.4.13 by Olaf van der Spek
Refactor Session
662
  index_hint_type current_index_hint_type;
1 by brian
clean slate
663
  index_clause_map current_index_hint_clause;
664
  /* a list of USE/FORCE/IGNORE INDEX */
665
  List<Index_hint> *index_hints;
666
};
667
2385.3.18 by Olaf van der Spek
Refactor
668
inline bool Select_Lex_Unit::is_union()
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
669
{
2385.3.18 by Olaf van der Spek
Refactor
670
  return first_select()->next_select() && first_select()->next_select()->linkage == UNION_TYPE;
1 by brian
clean slate
671
}
672
1014.4.9 by Jay Pipes
Code style cleanup and removal of dead LEX_SERVER_OPTIONS struct
673
enum xa_option_words
674
{
2385.3.18 by Olaf van der Spek
Refactor
675
  XA_NONE,
676
  XA_JOIN,
677
  XA_RESUME,
678
  XA_ONE_PHASE,
679
  XA_SUSPEND,
680
  XA_FOR_MIGRATE
1014.4.9 by Jay Pipes
Code style cleanup and removal of dead LEX_SERVER_OPTIONS struct
681
};
1 by brian
clean slate
682
683
/*
684
  Class representing list of all tables used by statement.
685
  It also contains information about stored functions used by statement
686
  since during its execution we may have to add all tables used by its
687
  stored functions/triggers to this list in order to pre-open and lock
688
  them.
689
690
  Also used by st_lex::reset_n_backup/restore_backup_query_tables_list()
691
  methods to save and restore this information.
692
*/
693
class Query_tables_list
694
{
695
public:
696
  /* Global list of all tables used by this statement */
327.2.4 by Brian Aker
Refactoring table.h
697
  TableList *query_tables;
1 by brian
clean slate
698
  /* Pointer to next_global member of last element in the previous list. */
327.2.4 by Brian Aker
Refactoring table.h
699
  TableList **query_tables_last;
1 by brian
clean slate
700
  /*
701
    If non-0 then indicates that query requires prelocking and points to
702
    next_global member of last own element in query table list (i.e. last
703
    table which was not added to it as part of preparation to prelocking).
704
    0 - indicates that this query does not need prelocking.
705
  */
327.2.4 by Brian Aker
Refactoring table.h
706
  TableList **query_tables_own_last;
1 by brian
clean slate
707
708
  /* Initializes (or resets) Query_tables_list object for "real" use. */
709
  void reset_query_tables_list(bool init);
710
711
  /*
712
    Direct addition to the list of query tables.
713
    If you are using this function, you must ensure that the table
714
    object, in particular table->db member, is initialized.
715
  */
327.2.4 by Brian Aker
Refactoring table.h
716
  void add_to_query_tables(TableList *table)
1 by brian
clean slate
717
  {
718
    *(table->prev_global= query_tables_last)= table;
719
    query_tables_last= &table->next_global;
720
  }
721
  /* Return pointer to first not-own table in query-tables or 0 */
327.2.4 by Brian Aker
Refactoring table.h
722
  TableList* first_not_own_table()
1 by brian
clean slate
723
  {
724
    return ( query_tables_own_last ? *query_tables_own_last : 0);
725
  }
726
  void chop_off_not_own_tables()
727
  {
728
    if (query_tables_own_last)
729
    {
730
      *query_tables_own_last= 0;
731
      query_tables_last= query_tables_own_last;
732
      query_tables_own_last= 0;
733
    }
734
  }
735
};
736
737
/**
738
  The state of the lexical parser, when parsing comments.
739
*/
740
enum enum_comment_state
741
{
742
  /**
743
    Not parsing comments.
744
  */
745
  NO_COMMENT,
746
  /**
747
    Parsing comments that need to be preserved.
748
    Typically, these are user comments '/' '*' ... '*' '/'.
749
  */
750
  PRESERVE_COMMENT,
751
  /**
752
    Parsing comments that need to be discarded.
753
    Typically, these are special comments '/' '*' '!' ... '*' '/',
754
    or '/' '*' '!' 'M' 'M' 'm' 'm' 'm' ... '*' '/', where the comment
755
    markers should not be expanded.
756
  */
757
  DISCARD_COMMENT
758
};
759
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
760
} /* namespace drizzled */
761
2318.8.7 by Olaf van der Spek
Add const
762
namespace drizzled {
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
763
520.1.21 by Brian Aker
THD -> Session rename
764
/* The state of the lex parsing. This is saved in the Session struct */
575.4.7 by Monty Taylor
More header cleanup.
765
class LEX : public Query_tables_list
1 by brian
clean slate
766
{
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
767
public:
848 by Brian Aker
typdef class removal (just... use the name of the class).
768
  Select_Lex_Unit unit;                         /* most upper unit */
846 by Brian Aker
Removing on typedeffed class.
769
  Select_Lex select_lex;                        /* first Select_Lex */
770
  /* current Select_Lex in parsing */
771
  Select_Lex *current_select;
772
  /* list of all Select_Lex */
773
  Select_Lex *all_selects_list;
1 by brian
clean slate
774
2227.4.3 by Olaf van der Spek
Remove unnecessary statement.h include
775
  /* This is the "scale" for DECIMAL (S,P) notation */
2318.8.6 by Olaf van der Spek
Add const
776
  const char *length;
1014.4.5 by Jay Pipes
Cleanup of LEX structure. Removed unused xid member variable, documented a number of member variables.
777
  /* This is the decimal precision in DECIMAL(S,P) notation */
2318.8.6 by Olaf van der Spek
Add const
778
  const char *dec;
2227.4.3 by Olaf van der Spek
Remove unnecessary statement.h include
779
1014.4.7 by Jay Pipes
More documentation of LEX member variables and removal of slave_session_opt unused member variable.
780
  /**
2227.4.3 by Olaf van der Spek
Remove unnecessary statement.h include
781
   * This is used kind of like the "ident" member variable below, as
1014.4.7 by Jay Pipes
More documentation of LEX member variables and removal of slave_session_opt unused member variable.
782
   * a place to store certain names of identifiers.  Unfortunately, it
783
   * is used differently depending on the Command (SELECT on a derived
784
   * table vs CREATE)
785
   */
2371.1.2 by Brian Aker
Remove the typedef on lexkey
786
  lex_string_t name;
1014.4.7 by Jay Pipes
More documentation of LEX member variables and removal of slave_session_opt unused member variable.
787
  /* The string literal used in a LIKE expression */
1 by brian
clean slate
788
  String *wild;
831.1.2 by Brian Aker
Rename class file_exchange
789
  file_exchange *exchange;
1 by brian
clean slate
790
  select_result *result;
1014.4.5 by Jay Pipes
Cleanup of LEX structure. Removed unused xid member variable, documented a number of member variables.
791
1014.4.7 by Jay Pipes
More documentation of LEX member variables and removal of slave_session_opt unused member variable.
792
  /**
793
   * This is current used to store the name of a named key cache
794
   * or a named savepoint.  It should probably be refactored out into
795
   * the eventual Command class built for the Keycache and Savepoint
796
   * commands.
2227.4.3 by Olaf van der Spek
Remove unnecessary statement.h include
797
   */
2371.1.2 by Brian Aker
Remove the typedef on lexkey
798
  lex_string_t ident;
1014.4.5 by Jay Pipes
Cleanup of LEX structure. Removed unused xid member variable, documented a number of member variables.
799
481 by Brian Aker
Remove all of uchar.
800
  unsigned char* yacc_yyss, *yacc_yyvs;
1014.4.7 by Jay Pipes
More documentation of LEX member variables and removal of slave_session_opt unused member variable.
801
  /* The owning Session of this LEX */
520.1.22 by Brian Aker
Second pass of thd cleanup
802
  Session *session;
2254 by Brian Aker
Shift CHARSET_INFO to charset_info_st
803
  const charset_info_st *charset;
1 by brian
clean slate
804
  bool text_string_is_7bit;
805
  /* store original leaf_tables for INSERT SELECT and PS/SP */
327.2.4 by Brian Aker
Refactoring table.h
806
  TableList *leaf_tables_insert;
1 by brian
clean slate
807
808
  List<Key_part_spec> col_list;
809
  List<Key_part_spec> ref_list;
810
  List<String>	      interval_list;
851 by Brian Aker
Class rewrite of Session (aka get all of the junk out)
811
  List<Lex_Column>    columns;
1 by brian
clean slate
812
  List<Item>	      *insert_list,field_list,value_list,update_list;
813
  List<List_item>     many_values;
2040.6.4 by Monty Taylor
Replaced List<set_var_base> with
814
  SetVarVector  var_list;
1 by brian
clean slate
815
  /*
816
    A stack of name resolution contexts for the query. This stack is used
817
    at parse time to set local name resolution contexts for various parts
818
    of a query. For example, in a JOIN ... ON (some_condition) clause the
819
    Items in 'some_condition' must be resolved only against the operands
820
    of the the join, and not against the whole clause. Similarly, Items in
821
    subqueries should be resolved against the subqueries (and outer queries).
822
    The stack is used in the following way: when the parser detects that
823
    all Items in some clause need a local context, it creates a new context
824
    and pushes it on the stack. All newly created Items always store the
825
    top-most context in the stack. Once the parser leaves the clause that
826
    required a local context, the parser pops the top-most context.
827
  */
828
  List<Name_resolution_context> context_stack;
829
1014.4.5 by Jay Pipes
Cleanup of LEX structure. Removed unused xid member variable, documented a number of member variables.
830
  SQL_LIST auxiliary_table_list;
831
  SQL_LIST save_list;
1052.2.3 by Nathan Williams
No actual code changes. Changed Create_field to CreateField to be consistent with coding standards.
832
  CreateField *last_field;
1 by brian
clean slate
833
  Item_sum *in_sum_func;
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
834
  plugin::Function *udf;
202 by Brian Aker
Cleanup sql_lex to modern types.
835
  uint32_t type;
1 by brian
clean slate
836
  /*
837
    This variable is used in post-parse stage to declare that sum-functions,
838
    or functions which have sense only if GROUP BY is present, are allowed.
839
    For example in a query
840
    SELECT ... FROM ...WHERE MIN(i) == 1 GROUP BY ... HAVING MIN(i) > 2
841
    MIN(i) in the WHERE clause is not allowed in the opposite to MIN(i)
842
    in the HAVING clause. Due to possible nesting of select construct
843
    the variable can contain 0 or 1 for each nest level.
844
  */
845
  nesting_map allow_sum_func;
846
  enum_sql_command sql_command;
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
847
  statement::Statement *statement;
1 by brian
clean slate
848
  /*
849
    Usually `expr` rule of yacc is quite reused but some commands better
850
    not support subqueries which comes standard with this rule, like
851
    KILL, HA_READ, CREATE/ALTER EVENT etc. Set this to `false` to get
852
    syntax error back.
853
  */
854
  bool expr_allows_subselect;
855
856
  thr_lock_type lock_option;
857
  enum enum_duplicates duplicates;
858
  union {
859
    enum ha_rkey_function ha_rkey_mode;
860
    enum xa_option_words xa_opt;
861
  };
1273.13.24 by Brian Aker
Updating style, simplified code.
862
  sql_var_t option_type;
1 by brian
clean slate
863
864
  int nest_level;
202 by Brian Aker
Cleanup sql_lex to modern types.
865
  uint8_t describe;
1 by brian
clean slate
866
  /*
867
    A flag that indicates what kinds of derived tables are present in the
868
    query (0 if no derived tables, otherwise DERIVED_SUBQUERY).
869
  */
202 by Brian Aker
Cleanup sql_lex to modern types.
870
  uint8_t derived_tables;
1014.4.7 by Jay Pipes
More documentation of LEX member variables and removal of slave_session_opt unused member variable.
871
872
  /* Was the IGNORE symbol found in statement */
1014.4.5 by Jay Pipes
Cleanup of LEX structure. Removed unused xid member variable, documented a number of member variables.
873
  bool ignore;
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
874
1 by brian
clean slate
875
  /**
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
876
    During name resolution search only in the table list given by
1 by brian
clean slate
877
    Name_resolution_context::first_name_resolution_table and
878
    Name_resolution_context::last_name_resolution_table
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
879
    (see Item_field::fix_fields()).
1 by brian
clean slate
880
  */
881
  bool use_only_table_context;
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
882
1014.4.7 by Jay Pipes
More documentation of LEX member variables and removal of slave_session_opt unused member variable.
883
  /* Was the ESCAPE keyword used? */
1 by brian
clean slate
884
  bool escape_used;
885
  bool is_lex_started; /* If lex_start() did run. For debugging. */
886
575.4.7 by Monty Taylor
More header cleanup.
887
  LEX();
1 by brian
clean slate
888
1008.3.17 by Stewart Smith
Start work to construct table proto in parser:
889
  /* Note that init and de-init mostly happen in lex_start and lex_end
890
     and not here. This is because LEX isn't delete/new for each new
891
     statement in a session. It's re-used by doing lex_end, lex_start
892
     in sql_lex.cc
893
  */
2029.1.2 by Brian Aker
Merge in refactor of LIKE up to its own calling pointer in the parser.
894
  virtual ~LEX();
1 by brian
clean slate
895
327.2.4 by Brian Aker
Refactoring table.h
896
  TableList *unlink_first_table(bool *link_to_local);
897
  void link_first_table_back(TableList *first, bool link_to_local);
1 by brian
clean slate
898
  void first_lists_tables_same();
899
900
  void cleanup_after_one_table_open();
901
2241.2.11 by Olaf van der Spek
Refactor
902
  void push_context(Name_resolution_context *context)
1 by brian
clean slate
903
  {
2241.2.11 by Olaf van der Spek
Refactor
904
    context_stack.push_front(context);
1 by brian
clean slate
905
  }
906
907
  void pop_context()
908
  {
909
    context_stack.pop();
910
  }
911
912
  Name_resolution_context *current_context()
913
  {
2183.2.21 by Olaf van der Spek
Use List::front()
914
    return &context_stack.front();
1 by brian
clean slate
915
  }
916
917
  /**
918
    @brief check if the statement is a single-level join
919
    @return result of the check
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
920
      @retval true  The statement doesn't contain subqueries, unions and
1 by brian
clean slate
921
                    stored procedure calls.
51.1.52 by Jay Pipes
Removed/replaced DBUG symbols and standardized TRUE/FALSE
922
      @retval false There are subqueries, UNIONs or stored procedure calls.
1 by brian
clean slate
923
  */
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
924
  bool is_single_level_stmt()
925
  {
926
    /*
1 by brian
clean slate
927
      This check exploits the fact that the last added to all_select_list is
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
928
      on its top. So select_lex (as the first added) will be at the tail
1 by brian
clean slate
929
      of the list.
660.1.3 by Eric Herman
removed trailing whitespace with simple script:
930
    */
628 by Brian Aker
Collection of dead code removal
931
    if (&select_lex == all_selects_list)
1 by brian
clean slate
932
    {
51.1.52 by Jay Pipes
Removed/replaced DBUG symbols and standardized TRUE/FALSE
933
      assert(!all_selects_list->next_select_in_list());
934
      return true;
1 by brian
clean slate
935
    }
51.1.52 by Jay Pipes
Removed/replaced DBUG symbols and standardized TRUE/FALSE
936
    return false;
1 by brian
clean slate
937
  }
1637.1.3 by Brian Aker
This fixes the parser to no longer do the bad syntax around the cross join
938
  bool is_cross; // CROSS keyword was used
1643.6.13 by Djellel E. Difallah
adding tests
939
  bool isCacheable()
940
  {
941
    return cacheable;
942
  }
943
  void setCacheable(bool val)
944
  {
945
    cacheable= val;
946
  }
1751.3.1 by Brian Aker
This add a couple of utility table functions to be used with testing.
947
948
  void reset()
949
  {
950
    sum_expr_used= false;
2029.1.5 by Brian Aker
Move exists into LEX.
951
    _exists= false;
1751.3.1 by Brian Aker
This add a couple of utility table functions to be used with testing.
952
  }
953
954
  void setSumExprUsed()
955
  {
956
    sum_expr_used= true;
957
  }
958
959
  bool isSumExprUsed()
960
  {
961
    return sum_expr_used;
962
  }
1897.1.5 by Brian Aker
Move lex_end to be class member.
963
1897.1.7 by Brian Aker
Partial encapsulation of lex_start.
964
  void start(Session *session);
1897.1.5 by Brian Aker
Move lex_end to be class member.
965
  void end();
966
2029.1.2 by Brian Aker
Merge in refactor of LIKE up to its own calling pointer in the parser.
967
  message::Table *table()
968
  {
969
    if (not _create_table)
970
      _create_table= new message::Table;
971
972
    return _create_table;
973
  }
974
2200.2.11 by Stewart Smith
move the message::AlterTable header include into sql_lex.cc so we can just have a forward declaration in sql_lex.h - greatly speeding compile time
975
  message::AlterTable *alter_table();
2200.2.2 by Stewart Smith
add very basic ALTER TABLE protobuf message and add the DEFAULT/OFFLINE/ONLINE build method member to it, assert that we're doing the right thing.
976
2029.1.20 by Brian Aker
Make use of lex for its pointer for field creation.
977
  message::Table::Field *field()
978
  {
979
    return _create_field;
980
  }
981
982
  void setField(message::Table::Field *arg)
983
  {
984
    _create_field= arg;
985
  }
986
2029.1.5 by Brian Aker
Move exists into LEX.
987
  void setExists()
988
  {
989
    _exists= true;
990
  }
991
992
  bool exists() const
993
  {
994
    return _exists;
995
  }
996
2227.4.3 by Olaf van der Spek
Remove unnecessary statement.h include
997
private:
1643.6.13 by Djellel E. Difallah
adding tests
998
  bool cacheable;
1751.3.1 by Brian Aker
This add a couple of utility table functions to be used with testing.
999
  bool sum_expr_used;
2029.1.2 by Brian Aker
Merge in refactor of LIKE up to its own calling pointer in the parser.
1000
  message::Table *_create_table;
2200.2.2 by Stewart Smith
add very basic ALTER TABLE protobuf message and add the DEFAULT/OFFLINE/ONLINE build method member to it, assert that we're doing the right thing.
1001
  message::AlterTable *_alter_table;
2029.1.20 by Brian Aker
Make use of lex for its pointer for field creation.
1002
  message::Table::Field *_create_field;
2029.1.5 by Brian Aker
Move exists into LEX.
1003
  bool _exists;
575.4.7 by Monty Taylor
More header cleanup.
1004
};
1 by brian
clean slate
1005
520.1.22 by Brian Aker
Second pass of thd cleanup
1006
extern void lex_start(Session *session);
2029.1.26 by Brian Aker
Merge in work for reserved words in SQL standard.
1007
1 by brian
clean slate
1008
/**
1009
  @} (End of group Semantic_Analysis)
1010
*/
1011
1280.1.10 by Monty Taylor
Put everything in drizzled into drizzled namespace.
1012
} /* namespace drizzled */
1013
319.1.1 by Grant Limberg
renamed all instances of MYSQL_ to DRIZZLE_
1014
#endif /* DRIZZLE_SERVER */