sql_lex.h 54.8 KB
Newer Older
unknown's avatar
unknown committed
1
/* Copyright (C) 2000-2006 MySQL AB
unknown's avatar
unknown committed
2

unknown's avatar
unknown committed
3 4
   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
unknown's avatar
unknown committed
5
   the Free Software Foundation; version 2 of the License.
unknown's avatar
unknown committed
6

unknown's avatar
unknown committed
7 8 9 10
   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.
unknown's avatar
unknown committed
11

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


/* YACC and LEX Definitions */

/* These may not be declared yet */
class Table_ident;
class sql_exchange;
class LEX_COLUMN;
23
class sp_head;
24
class sp_name;
25 26
class sp_instr;
class sp_pcontext;
unknown's avatar
unknown committed
27
class st_alter_tablespace;
28
class partition_info;
29
class Event_parse_data;
unknown's avatar
unknown committed
30

31
#ifdef MYSQL_SERVER
32 33 34 35
/*
  The following hack is needed because mysql_yacc.cc does not define
  YYSTYPE before including this file
*/
unknown's avatar
unknown committed
36

unknown's avatar
unknown committed
37 38
#include "set_var.h"

unknown's avatar
unknown committed
39 40 41 42
#ifdef MYSQL_YACC
#define LEX_YYSTYPE void *
#else
#include "lex_symbol.h"
43
#if MYSQL_LEX
unknown's avatar
unknown committed
44 45
#include "sql_yacc.h"
#define LEX_YYSTYPE YYSTYPE *
46 47 48
#else
#define LEX_YYSTYPE void *
#endif
unknown's avatar
unknown committed
49
#endif
50
#endif
unknown's avatar
unknown committed
51

52 53 54
/*
  When a command is added here, be sure it's also added in mysqld.cc
  in "struct show_var_st status_vars[]= {" ...
55 56 57 58 59

  If the command returns a result set or is not allowed in stored
  functions or triggers, please also make sure that
  sp_get_flags_for_command (sp_head.cc) returns proper flags for the
  added SQLCOM_.
60 61
*/

unknown's avatar
unknown committed
62
enum enum_sql_command {
63 64 65 66 67
  SQLCOM_SELECT, SQLCOM_CREATE_TABLE, SQLCOM_CREATE_INDEX, SQLCOM_ALTER_TABLE,
  SQLCOM_UPDATE, SQLCOM_INSERT, SQLCOM_INSERT_SELECT,
  SQLCOM_DELETE, SQLCOM_TRUNCATE, SQLCOM_DROP_TABLE, SQLCOM_DROP_INDEX,

  SQLCOM_SHOW_DATABASES, SQLCOM_SHOW_TABLES, SQLCOM_SHOW_FIELDS,
68 69
  SQLCOM_SHOW_KEYS, SQLCOM_SHOW_VARIABLES, SQLCOM_SHOW_STATUS,
  SQLCOM_SHOW_ENGINE_LOGS, SQLCOM_SHOW_ENGINE_STATUS, SQLCOM_SHOW_ENGINE_MUTEX,
70
  SQLCOM_SHOW_PROCESSLIST, SQLCOM_SHOW_MASTER_STAT, SQLCOM_SHOW_SLAVE_STAT,
71
  SQLCOM_SHOW_GRANTS, SQLCOM_SHOW_CREATE, SQLCOM_SHOW_CHARSETS,
72
  SQLCOM_SHOW_COLLATIONS, SQLCOM_SHOW_CREATE_DB, SQLCOM_SHOW_TABLE_STATUS,
73
  SQLCOM_SHOW_TRIGGERS,
74

unknown's avatar
unknown committed
75
  SQLCOM_LOAD,SQLCOM_SET_OPTION,SQLCOM_LOCK_TABLES,SQLCOM_UNLOCK_TABLES,
76
  SQLCOM_GRANT,
77
  SQLCOM_CHANGE_DB, SQLCOM_CREATE_DB, SQLCOM_DROP_DB, SQLCOM_ALTER_DB,
unknown's avatar
unknown committed
78
  SQLCOM_RENAME_DB,
79
  SQLCOM_REPAIR, SQLCOM_REPLACE, SQLCOM_REPLACE_SELECT,
80
  SQLCOM_CREATE_FUNCTION, SQLCOM_DROP_FUNCTION,
81
  SQLCOM_REVOKE,SQLCOM_OPTIMIZE, SQLCOM_CHECK,
unknown's avatar
unknown committed
82
  SQLCOM_ASSIGN_TO_KEYCACHE, SQLCOM_PRELOAD_KEYS,
83
  SQLCOM_FLUSH, SQLCOM_KILL, SQLCOM_ANALYZE,
unknown's avatar
unknown committed
84
  SQLCOM_ROLLBACK, SQLCOM_ROLLBACK_TO_SAVEPOINT,
unknown's avatar
unknown committed
85
  SQLCOM_COMMIT, SQLCOM_SAVEPOINT, SQLCOM_RELEASE_SAVEPOINT,
86
  SQLCOM_SLAVE_START, SQLCOM_SLAVE_STOP,
87
  SQLCOM_BEGIN, SQLCOM_LOAD_MASTER_TABLE, SQLCOM_CHANGE_MASTER,
unknown's avatar
unknown committed
88
  SQLCOM_RENAME_TABLE, SQLCOM_BACKUP_TABLE, SQLCOM_RESTORE_TABLE,
89
  SQLCOM_RESET, SQLCOM_PURGE, SQLCOM_PURGE_BEFORE, SQLCOM_SHOW_BINLOGS,
90
  SQLCOM_SHOW_OPEN_TABLES, SQLCOM_LOAD_MASTER_DATA,
91
  SQLCOM_HA_OPEN, SQLCOM_HA_CLOSE, SQLCOM_HA_READ,
92
  SQLCOM_SHOW_SLAVE_HOSTS, SQLCOM_DELETE_MULTI, SQLCOM_UPDATE_MULTI,
unknown's avatar
unknown committed
93
  SQLCOM_SHOW_BINLOG_EVENTS, SQLCOM_SHOW_NEW_MASTER, SQLCOM_DO,
unknown's avatar
unknown committed
94
  SQLCOM_SHOW_WARNS, SQLCOM_EMPTY_QUERY, SQLCOM_SHOW_ERRORS,
unknown's avatar
unknown committed
95
  SQLCOM_SHOW_COLUMN_TYPES, SQLCOM_SHOW_STORAGE_ENGINES, SQLCOM_SHOW_PRIVILEGES,
96 97
  SQLCOM_HELP, SQLCOM_CREATE_USER, SQLCOM_DROP_USER, SQLCOM_RENAME_USER,
  SQLCOM_REVOKE_ALL, SQLCOM_CHECKSUM,
98
  SQLCOM_CREATE_PROCEDURE, SQLCOM_CREATE_SPFUNCTION, SQLCOM_CALL,
99
  SQLCOM_DROP_PROCEDURE, SQLCOM_ALTER_PROCEDURE,SQLCOM_ALTER_FUNCTION,
unknown's avatar
unknown committed
100 101
  SQLCOM_SHOW_CREATE_PROC, SQLCOM_SHOW_CREATE_FUNC,
  SQLCOM_SHOW_STATUS_PROC, SQLCOM_SHOW_STATUS_FUNC,
unknown's avatar
unknown committed
102
  SQLCOM_PREPARE, SQLCOM_EXECUTE, SQLCOM_DEALLOCATE_PREPARE,
unknown's avatar
VIEW  
unknown committed
103
  SQLCOM_CREATE_VIEW, SQLCOM_DROP_VIEW,
104
  SQLCOM_CREATE_TRIGGER, SQLCOM_DROP_TRIGGER,
105 106
  SQLCOM_XA_START, SQLCOM_XA_END, SQLCOM_XA_PREPARE,
  SQLCOM_XA_COMMIT, SQLCOM_XA_ROLLBACK, SQLCOM_XA_RECOVER,
unknown's avatar
unknown committed
107
  SQLCOM_SHOW_PROC_CODE, SQLCOM_SHOW_FUNC_CODE,
unknown's avatar
unknown committed
108
  SQLCOM_ALTER_TABLESPACE,
109
  SQLCOM_INSTALL_PLUGIN, SQLCOM_UNINSTALL_PLUGIN,
110 111
  SQLCOM_SHOW_AUTHORS, SQLCOM_BINLOG_BASE64_EVENT,
  SQLCOM_SHOW_PLUGINS,
112
  SQLCOM_SHOW_CONTRIBUTORS,
unknown's avatar
unknown committed
113
  SQLCOM_CREATE_SERVER, SQLCOM_DROP_SERVER, SQLCOM_ALTER_SERVER,
114
  SQLCOM_CREATE_EVENT, SQLCOM_ALTER_EVENT, SQLCOM_DROP_EVENT,
unknown's avatar
unknown committed
115 116
  SQLCOM_SHOW_CREATE_EVENT, SQLCOM_SHOW_EVENTS,
  SQLCOM_SHOW_CREATE_TRIGGER,
unknown's avatar
unknown committed
117

118
  /* This should be the last !!! */
119

120
  SQLCOM_END
unknown's avatar
unknown committed
121 122
};

unknown's avatar
unknown committed
123 124 125
// describe/explain types
#define DESCRIBE_NORMAL		1
#define DESCRIBE_EXTENDED	2
unknown's avatar
unknown committed
126
/*
127
  This is not within #ifdef because we want "EXPLAIN PARTITIONS ..." to produce
unknown's avatar
unknown committed
128 129 130
  additional "partitions" column even if partitioning is not compiled in.
*/
#define DESCRIBE_PARTITIONS	4
unknown's avatar
unknown committed
131

132 133
#ifdef MYSQL_SERVER

134
enum enum_sp_suid_behaviour
unknown's avatar
unknown committed
135
{
136 137 138
  SP_IS_DEFAULT_SUID= 0,
  SP_IS_NOT_SUID,
  SP_IS_SUID
unknown's avatar
unknown committed
139
};
140

141 142 143 144 145 146 147 148 149
enum enum_sp_data_access
{
  SP_DEFAULT_ACCESS= 0,
  SP_CONTAINS_SQL,
  SP_NO_SQL,
  SP_READS_SQL_DATA,
  SP_MODIFIES_SQL_DATA
};

150 151
const LEX_STRING sp_data_access_name[]=
{
unknown's avatar
unknown committed
152 153 154 155 156
  { C_STRING_WITH_LEN("") },
  { C_STRING_WITH_LEN("CONTAINS SQL") },
  { C_STRING_WITH_LEN("NO SQL") },
  { C_STRING_WITH_LEN("READS SQL DATA") },
  { C_STRING_WITH_LEN("MODIFIES SQL DATA") }
157
};
158

unknown's avatar
VIEW  
unknown committed
159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175
#define DERIVED_SUBQUERY	1
#define DERIVED_VIEW		2

enum enum_view_create_mode
{
  VIEW_CREATE_NEW,		// check that there are not such VIEW/table
  VIEW_ALTER,			// check that VIEW .frm with such name exists
  VIEW_CREATE_OR_REPLACE	// check only that there are not such table
};

enum enum_drop_mode
{
  DROP_DEFAULT, // mode is not specified
  DROP_CASCADE, // CASCADE option
  DROP_RESTRICT // RESTRICT option
};

unknown's avatar
unknown committed
176 177
typedef List<Item> List_item;

unknown's avatar
unknown committed
178 179 180 181 182 183 184 185
/* SERVERS CACHE CHANGES */
typedef struct st_lex_server_options
{
  long port;
  uint server_name_length;
  char *server_name, *host, *db, *username, *password, *scheme, *socket, *owner;
} LEX_SERVER_OPTIONS;

unknown's avatar
unknown committed
186 187
typedef struct st_lex_master_info
{
188
  char *host, *user, *password, *log_file_name;
unknown's avatar
unknown committed
189 190
  uint port, connect_retry;
  ulonglong pos;
unknown's avatar
unknown committed
191
  ulong server_id;
192 193 194 195 196 197
  /*
    Enum is used for making it possible to detect if the user
    changed variable or if it should be left at old value
   */
  enum {SSL_UNCHANGED, SSL_DISABLE, SSL_ENABLE}
    ssl, ssl_verify_server_cert;
unknown's avatar
unknown committed
198
  char *ssl_key, *ssl_cert, *ssl_ca, *ssl_capath, *ssl_cipher;
199
  char *relay_log_name;
200
  ulong relay_log_pos;
unknown's avatar
unknown committed
201 202
} LEX_MASTER_INFO;

203

204 205
enum sub_select_type
{
unknown's avatar
unknown committed
206 207
  UNSPECIFIED_TYPE,UNION_TYPE, INTERSECT_TYPE,
  EXCEPT_TYPE, GLOBAL_OPTIONS_TYPE, DERIVED_TABLE_TYPE, OLAP_TYPE
208 209 210 211
};

enum olap_type 
{
212
  UNSPECIFIED_OLAP_TYPE, CUBE_TYPE, ROLLUP_TYPE
213
};
214

unknown's avatar
unknown committed
215 216 217 218 219
enum tablespace_op_type
{
  NO_TABLESPACE_OP, DISCARD_TABLESPACE, IMPORT_TABLESPACE
};

220 221 222 223 224
/* 
  String names used to print a statement with index hints.
  Keep in sync with index_hint_type.
*/
extern const char * index_hint_type_name[];
225
typedef uchar index_clause_map;
226 227 228 229 230 231 232 233 234 235 236 237 238

/*
  Bits in index_clause_map : one for each possible FOR clause in
  USE/FORCE/IGNORE INDEX index hint specification
*/
#define INDEX_HINT_MASK_JOIN  (1)
#define INDEX_HINT_MASK_GROUP (1 << 1)
#define INDEX_HINT_MASK_ORDER (1 << 2)

#define INDEX_HINT_MASK_ALL (INDEX_HINT_MASK_JOIN | INDEX_HINT_MASK_GROUP | \
                             INDEX_HINT_MASK_ORDER)

/* Single element of an USE/FORCE/IGNORE INDEX list specified as a SQL hint  */
unknown's avatar
unknown committed
239
class Index_hint : public Sql_alloc
240 241 242 243 244 245 246 247 248 249 250 251
{
public:
  /* The type of the hint : USE/FORCE/IGNORE */
  enum index_hint_type type;
  /* Where the hit applies to. A bitmask of INDEX_HINT_MASK_<place> values */
  index_clause_map clause;
  /* 
    The index name. Empty (str=NULL) name represents an empty list 
    USE INDEX () clause 
  */ 
  LEX_STRING key_name;

unknown's avatar
unknown committed
252
  Index_hint (enum index_hint_type type_arg, index_clause_map clause_arg,
253 254 255 256 257 258 259 260
              char *str, uint length) :
    type(type_arg), clause(clause_arg)
  {
    key_name.str= str;
    key_name.length= length;
  }
}; 

unknown's avatar
unknown committed
261 262 263
/* 
  The state of the lex parsing for selects 
   
264 265 266 267 268 269 270 271 272 273
   master and slaves are pointers to select_lex.
   master is pointer to upper level node.
   slave is pointer to lower level node
   select_lex is a SELECT without union
   unit is container of either
     - One SELECT
     - UNION of selects
   select_lex and unit are both inherited form select_lex_node
   neighbors are two select_lex or units on the same level

unknown's avatar
unknown committed
274
   All select describing structures linked with following pointers:
275
   - list of neighbors (next/prev) (prev of first element point to slave
unknown's avatar
unknown committed
276
     pointer of upper structure)
277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303
     - For select this is a list of UNION's (or one element list)
     - For units this is a list of sub queries for the upper level select

   - pointer to master (master), which is
     If this is a unit
       - pointer to outer select_lex
     If this is a select_lex
       - pointer to outer unit structure for select

   - pointer to slave (slave), which is either:
     If this is a unit:
       - first SELECT that belong to this unit
     If this is a select_lex
       - first unit that belong to this SELECT (subquries or derived tables)

   - list of all select_lex (link_next/link_prev)
     This is to be used for things like derived tables creation, where we
     go through this list and create the derived tables.

   If unit contain several selects (UNION now, INTERSECT etc later)
   then it have special select_lex called fake_select_lex. It used for
   storing global parameters (like ORDER BY, LIMIT) and executing union.
   Subqueries used in global ORDER BY clause will be attached to this
   fake_select_lex, which will allow them correctly resolve fields of
   'upper' UNION and outer selects.

   For example for following query:
304

unknown's avatar
unknown committed
305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320
   select *
     from table1
     where table1.field IN (select * from table1_1_1 union
                            select * from table1_1_2)
     union
   select *
     from table2
     where table2.field=(select (select f1 from table2_1_1_1_1
                                   where table2_1_1_1_1.f2=table2_1_1.f3)
                           from table2_1_1
                           where table2_1_1.f1=table2.f2)
     union
   select * from table3;

   we will have following structure:

321 322 323 324 325
   select1: (select * from table1 ...)
   select2: (select * from table2 ...)
   select3: (select * from table3)
   select1.1.1: (select * from table1_1_1)
   ...
unknown's avatar
unknown committed
326 327

     main unit
unknown's avatar
unknown committed
328
     fake0
unknown's avatar
unknown committed
329 330 331 332 333 334 335 336
     select1 select2 select3
     |^^     |^
    s|||     ||master
    l|||     |+---------------------------------+
    a|||     +---------------------------------+|
    v|||master                         slave   ||
    e||+-------------------------+             ||
     V|            neighbor      |             V|
unknown's avatar
unknown committed
337
     unit1.1<+==================>unit1.2       unit2.1
unknown's avatar
unknown committed
338 339
     fake1.1
     select1.1.1 select 1.1.2    select1.2.1   select2.1.1
unknown's avatar
unknown committed
340 341 342 343 344 345 346 347
                                               |^
                                               ||
                                               V|
                                               unit2.1.1.1
                                               select2.1.1.1.1


   relation in main unit will be following:
348 349 350 351 352 353
   (bigger picture for:
      main unit
      fake0
      select1 select2 select3
   in the above picture)

unknown's avatar
unknown committed
354
         main unit
unknown's avatar
unknown committed
355 356 357 358 359 360 361 362
         |^^^^|fake_select_lex
         |||||+--------------------------------------------+
         ||||+--------------------------------------------+|
         |||+------------------------------+              ||
         ||+--------------+                |              ||
    slave||master         |                |              ||
         V|      neighbor |       neighbor |        master|V
         select1<========>select2<========>select3        fake0
unknown's avatar
unknown committed
363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378

    list of all select_lex will be following (as it will be constructed by
    parser):

    select1->select2->select3->select2.1.1->select 2.1.2->select2.1.1.1.1-+
                                                                          |
    +---------------------------------------------------------------------+
    |
    +->select1.1.1->select1.1.2

*/

/* 
    Base class for st_select_lex (SELECT_LEX) & 
    st_select_lex_unit (SELECT_LEX_UNIT)
*/
unknown's avatar
unknown committed
379
struct st_lex;
380 381
class st_select_lex;
class st_select_lex_unit;
382 383
class st_select_lex_node {
protected:
unknown's avatar
unknown committed
384 385 386
  st_select_lex_node *next, **prev,   /* neighbor list */
    *master, *slave,                  /* vertical links */
    *link_next, **link_prev;          /* list of whole SELECT_LEX */
387
public:
unknown's avatar
unknown committed
388

389
  ulonglong options;
390 391 392 393 394 395 396 397

  /*
    In sql_cache we store SQL_CACHE flag as specified by user to be
    able to restore SELECT statement from internal structures.
  */
  enum e_sql_cache { SQL_CACHE_UNSPECIFIED, SQL_NO_CACHE, SQL_CACHE };
  e_sql_cache sql_cache;

398 399 400 401
  /*
    result of this query can't be cached, bit field, can be :
      UNCACHEABLE_DEPENDENT
      UNCACHEABLE_RAND
402
      UNCACHEABLE_SIDEEFFECT
403
      UNCACHEABLE_EXPLAIN
404
      UNCACHEABLE_PREPARE
405 406
  */
  uint8 uncacheable;
407
  enum sub_select_type linkage;
unknown's avatar
unknown committed
408
  bool no_table_names_allowed; /* used for global order by */
409
  bool no_error; /* suppress error message (convert it to warnings) */
410 411 412

  static void *operator new(size_t size)
  {
413
    return sql_alloc(size);
414
  }
unknown's avatar
unknown committed
415 416
  static void *operator new(size_t size, MEM_ROOT *mem_root)
  { return (void*) alloc_root(mem_root, (uint) size); }
unknown's avatar
unknown committed
417
  static void operator delete(void *ptr,size_t size) { TRASH(ptr, size); }
418
  static void operator delete(void *ptr, MEM_ROOT *mem_root) {}
419
  st_select_lex_node(): linkage(UNSPECIFIED_TYPE) {}
420 421 422 423
  virtual ~st_select_lex_node() {}
  inline st_select_lex_node* get_master() { return master; }
  virtual void init_query();
  virtual void init_select();
unknown's avatar
unknown committed
424 425
  void include_down(st_select_lex_node *upper);
  void include_neighbour(st_select_lex_node *before);
unknown's avatar
unknown committed
426
  void include_standalone(st_select_lex_node *sel, st_select_lex_node **ref);
unknown's avatar
unknown committed
427 428
  void include_global(st_select_lex_node **plink);
  void exclude();
429 430 431

  virtual st_select_lex_unit* master_unit()= 0;
  virtual st_select_lex* outer_select()= 0;
unknown's avatar
unknown committed
432
  virtual st_select_lex* return_after_parsing()= 0;
433 434 435 436 437 438

  virtual bool set_braces(bool value);
  virtual bool inc_in_sum_expr();
  virtual uint get_in_sum_expr();
  virtual TABLE_LIST* get_table_list();
  virtual List<Item>* get_item_list();
unknown's avatar
unknown committed
439
  virtual ulong get_table_join_options();
unknown's avatar
unknown committed
440
  virtual TABLE_LIST *add_table_to_list(THD *thd, Table_ident *table,
441
					LEX_STRING *alias,
unknown's avatar
unknown committed
442
					ulong table_options,
443
					thr_lock_type flags= TL_UNLOCK,
unknown's avatar
unknown committed
444
					List<Index_hint> *hints= 0,
unknown's avatar
unknown committed
445
                                        LEX_STRING *option= 0);
unknown's avatar
unknown committed
446
  virtual void set_lock_for_tables(thr_lock_type lock_type) {}
unknown's avatar
unknown committed
447

unknown's avatar
unknown committed
448
  friend class st_select_lex_unit;
unknown's avatar
unknown committed
449
  friend bool mysql_new_select(struct st_lex *lex, bool move_down);
450
  friend bool mysql_make_view(THD *thd, File_parser *parser,
451
                              TABLE_LIST *table, uint flags);
unknown's avatar
unknown committed
452 453 454
private:
  void fast_exclude();
};
455
typedef class st_select_lex_node SELECT_LEX_NODE;
unknown's avatar
unknown committed
456 457 458 459 460

/* 
   SELECT_LEX_UNIT - unit of selects (UNION, INTERSECT, ...) group 
   SELECT_LEXs
*/
unknown's avatar
unknown committed
461 462 463 464
class THD;
class select_result;
class JOIN;
class select_union;
465
class Procedure;
466
class st_select_lex_unit: public st_select_lex_node {
unknown's avatar
unknown committed
467 468 469 470
protected:
  TABLE_LIST result_table_list;
  select_union *union_result;
  TABLE *table; /* temporary table using for appending UNION results */
471

unknown's avatar
unknown committed
472
  select_result *result;
473
  ulonglong found_rows_for_union;
474 475
  bool saved_error;

476
public:
unknown's avatar
unknown committed
477
  bool  prepared, // prepare phase already performed for UNION (unit)
unknown's avatar
unknown committed
478
    optimized, // optimize phase already performed for UNION (unit)
479 480
    executed, // already executed
    cleaned;
481 482 483

  // list of fields which points to temporary table for union
  List<Item> item_list;
unknown's avatar
unknown committed
484 485 486 487 488 489 490
  /*
    list of types of items inside union (used for union & derived tables)
    
    Item_type_holders from which this list consist may have pointers to Field,
    pointers is valid only after preparing SELECTS of this unit and before
    any SELECT of this unit execution
  */
491
  List<Item> types;
unknown's avatar
unknown committed
492 493 494 495
  /*
    Pointer to 'last' select or pointer to unit where stored
    global parameters for union
  */
unknown's avatar
unknown committed
496
  st_select_lex *global_parameters;
497
  //node on wich we should return current_select pointer after parsing subquery
unknown's avatar
unknown committed
498
  st_select_lex *return_to;
unknown's avatar
unknown committed
499 500
  /* LIMIT clause runtime counters */
  ha_rows select_limit_cnt, offset_limit_cnt;
501
  /* not NULL if unit used in subselect, point to subselect item */
unknown's avatar
unknown committed
502
  Item_subselect *item;
unknown's avatar
unknown committed
503
  /* thread handler */
504
  THD *thd;
unknown's avatar
unknown committed
505 506 507 508
  /*
    SELECT_LEX for hidden SELECT in onion which process global
    ORDER BY and LIMIT
  */
unknown's avatar
unknown committed
509
  st_select_lex *fake_select_lex;
510

511
  st_select_lex *union_distinct; /* pointer to the last UNION DISTINCT */
512
  bool describe; /* union exec() called for EXPLAIN */
513
  Procedure *last_procedure;	 /* Pointer to procedure, if such exists */
unknown's avatar
unknown committed
514

unknown's avatar
unknown committed
515
  void init_query();
516 517
  st_select_lex_unit* master_unit();
  st_select_lex* outer_select();
518 519 520 521 522 523 524
  st_select_lex* first_select()
  {
    return my_reinterpret_cast(st_select_lex*)(slave);
  }
  st_select_lex_unit* next_unit()
  {
    return my_reinterpret_cast(st_select_lex_unit*)(next);
525
  }
unknown's avatar
unknown committed
526
  st_select_lex* return_after_parsing() { return return_to; }
unknown's avatar
unknown committed
527
  void exclude_level();
528
  void exclude_tree();
529

unknown's avatar
unknown committed
530
  /* UNION methods */
531
  bool prepare(THD *thd, select_result *result, ulong additional_options);
unknown's avatar
unknown committed
532 533
  bool exec();
  bool cleanup();
534
  inline void unclean() { cleaned= 0; }
unknown's avatar
unknown committed
535
  void reinit_exec_mechanism();
unknown's avatar
unknown committed
536 537

  void print(String *str);
538

unknown's avatar
unknown committed
539
  bool add_fake_select_lex(THD *thd);
540
  void init_prepare_fake_select_lex(THD *thd);
541
  inline bool is_prepared() { return prepared; }
unknown's avatar
unknown committed
542
  bool change_result(select_subselect *result, select_subselect *old_result);
543
  void set_limit(st_select_lex *values);
544
  void set_thd(THD *thd_arg) { thd= thd_arg; }
unknown's avatar
unknown committed
545
  inline bool is_union (); 
unknown's avatar
unknown committed
546

547
  friend void lex_start(THD *thd);
548
  friend int subselect_union_engine::exec();
549 550

  List<Item> *get_unit_column_types();
unknown's avatar
unknown committed
551
};
552

unknown's avatar
unknown committed
553
typedef class st_select_lex_unit SELECT_LEX_UNIT;
unknown's avatar
unknown committed
554 555

/*
556
  SELECT_LEX - store information of parsed SELECT statment
unknown's avatar
unknown committed
557
*/
558 559
class st_select_lex: public st_select_lex_node
{
560
public:
561
  Name_resolution_context context;
unknown's avatar
unknown committed
562
  char *db;
unknown's avatar
unknown committed
563
  Item *where, *having;                         /* WHERE & HAVING clauses */
564
  Item *prep_where; /* saved WHERE clause for prepared statement processing */
unknown's avatar
unknown committed
565
  Item *prep_having;/* saved HAVING clause for prepared statement processing */
566 567
  /* Saved values of the WHERE and HAVING clauses*/
  Item::cond_result cond_value, having_value;
unknown's avatar
VIEW  
unknown committed
568 569
  /* point on lex in which it was created, used in view subquery detection */
  st_lex *parent_lex;
570
  enum olap_type olap;
unknown's avatar
unknown committed
571 572 573 574
  /* FROM clause - points to the beginning of the TABLE_LIST::next_local list. */
  SQL_LIST	      table_list;
  SQL_LIST	      group_list; /* GROUP BY clause. */
  List<Item>          item_list;  /* list of fields & expressions */
575
  List<String>        interval_list;
unknown's avatar
unknown committed
576
  bool	              is_item_list_lookup;
unknown's avatar
unknown committed
577 578 579 580 581 582
  /* 
    Usualy it is pointer to ftfunc_list_alloc, but in union used to create fake
    select_lex for calling mysql_select under results of union
  */
  List<Item_func_match> *ftfunc_list;
  List<Item_func_match> ftfunc_list_alloc;
unknown's avatar
unknown committed
583
  JOIN *join; /* after JOIN::prepare it is pointer to corresponding JOIN */
584
  List<TABLE_LIST> top_join_list; /* join list of the top level          */
585
  List<TABLE_LIST> *join_list;    /* list for the currently parsed join  */
586
  TABLE_LIST *embedding;          /* table embedding to the above list   */
unknown's avatar
unknown committed
587 588 589 590 591 592
  /*
    Beginning of the list of leaves in a FROM clause, where the leaves
    inlcude all base tables including view tables. The tables are connected
    by TABLE_LIST::next_leaf, so leaf_tables points to the left-most leaf.
  */
  TABLE_LIST *leaf_tables;
593
  const char *type;               /* type of select for EXPLAIN          */
unknown's avatar
unknown committed
594 595 596

  SQL_LIST order_list;                /* ORDER clause */
  List<List_item>     expr_list;
unknown's avatar
unknown committed
597
  SQL_LIST *gorder_list;
598
  Item *select_limit, *offset_limit;  /* LIMIT clause parameters */
unknown's avatar
unknown committed
599 600 601
  // Arrays of pointers to top elements of all_fields list
  Item **ref_pointer_array;

unknown's avatar
merge  
unknown committed
602 603 604 605 606 607
  /*
    number of items in select_list and HAVING clause used to get number
    bigger then can be number of entries that will be added to all item
    list during split_sum_func
  */
  uint select_n_having_items;
608
  uint cond_count;    /* number of arguments of and/or/xor in where/having/on */
unknown's avatar
unknown committed
609 610
  uint between_count; /* number of between predicates in where/having/on      */
  uint max_equal_elems; /* maximal number of elements in multiple equalities  */   
unknown's avatar
unknown committed
611 612 613 614 615
  /*
    Number of fields used in select list or where clause of current select
    and all inner subselects.
  */
  uint select_n_where_fields;
unknown's avatar
unknown committed
616 617
  enum_parsing_place parsing_place; /* where we are parsing expression */
  bool with_sum_func;   /* sum function indicator */
618 619 620 621 622
  /* 
    PS or SP cond natural joins was alredy processed with permanent
    arena and all additional items which we need alredy stored in it
  */
  bool conds_processed_with_permanent_arena;
unknown's avatar
unknown committed
623

unknown's avatar
unknown committed
624
  ulong table_join_options;
625
  uint in_sum_expr;
unknown's avatar
unknown committed
626
  uint select_number; /* number of select (used for EXPLAIN) */
unknown's avatar
unknown committed
627 628
  int nest_level;     /* nesting level of select */
  Item_sum *inner_sum_func_list; /* list of sum func in nested selects */ 
629
  uint with_wild; /* item list contain '*' */
unknown's avatar
unknown committed
630 631 632
  bool  braces;   	/* SELECT ... UNION (SELECT ... ) <- this braces */
  /* TRUE when having fix field called in processing of this SELECT */
  bool having_fix_field;
633 634
  /* List of references to fields referenced from inner selects */
  List<Item_outer_ref> inner_refs_list;
635 636 637 638 639
  /* Number of Item_sum-derived objects in this SELECT */
  uint n_sum_items;
  /* Number of Item_sum-derived objects in children and descendant SELECTs */
  uint n_child_sum_items;

640 641
  /* explicit LIMIT clause was used */
  bool explicit_limit;
642 643 644 645 646
  /*
    there are subquery in HAVING clause => we can't close tables before
    query processing end even if we use temporary table
  */
  bool subquery_in_having;
647 648
  /* TRUE <=> this SELECT is correlated w.r.t. some ancestor select */
  bool is_correlated;
649 650 651 652 653 654 655 656 657 658 659 660 661
  /*
    This variable is required to ensure proper work of subqueries and
    stored procedures. Generally, one should use the states of
    Query_arena to determine if it's a statement prepare or first
    execution of a stored procedure. However, in case when there was an
    error during the first execution of a stored procedure, the SP body
    is not expelled from the SP cache. Therefore, a deeply nested
    subquery might be left unoptimized. So we need this per-subquery
    variable to inidicate the optimization/execution state of every
    subquery. Prepared statements work OK in that regard, as in
    case of an error during prepare the PS is not created.
  */
  bool first_execution;
unknown's avatar
unknown committed
662
  bool first_cond_optimization;
unknown's avatar
unknown committed
663 664
  /* do not wrap view fields with Item_ref */
  bool no_wrap_view_item;
665 666
  /* exclude this select from check of unique_table() */
  bool exclude_from_table_unique_test;
667 668 669 670
  /* List of fields that aren't under an aggregate function */
  List<Item_field> non_agg_fields;
  /* index in the select list of the expression currently being fixed */
  int cur_pos_in_select_list;
671

672
  List<udf_func>     udf_list;                  /* udf function calls stack */
673 674 675 676 677 678 679 680 681 682 683 684 685 686
  /* 
    This is a copy of the original JOIN USING list that comes from
    the parser. The parser :
      1. Sets the natural_join of the second TABLE_LIST in the join
         and the st_select_lex::prev_join_using.
      2. Makes a parent TABLE_LIST and sets its is_natural_join/
       join_using_fields members.
      3. Uses the wrapper TABLE_LIST as a table in the upper level.
    We cannot assign directly to join_using_fields in the parser because
    at stage (1.) the parent TABLE_LIST is not constructed yet and
    the assignment will override the JOIN USING fields of the lower level
    joins on the right.
  */
  List<String> *prev_join_using;
unknown's avatar
unknown committed
687 688
  void init_query();
  void init_select();
689
  st_select_lex_unit* master_unit();
690 691 692 693
  st_select_lex_unit* first_inner_unit() 
  { 
    return (st_select_lex_unit*) slave; 
  }
694
  st_select_lex* outer_select();
695
  st_select_lex* next_select() { return (st_select_lex*) next; }
696
  st_select_lex* next_select_in_list() 
697 698 699 700 701 702 703
  {
    return (st_select_lex*) link_next;
  }
  st_select_lex_node** next_select_in_list_addr()
  {
    return &link_next;
  }
unknown's avatar
unknown committed
704
  st_select_lex* return_after_parsing()
705 706 707
  {
    return master_unit()->return_after_parsing();
  }
708

unknown's avatar
unknown committed
709 710
  void mark_as_dependent(st_select_lex *last);

711 712 713
  bool set_braces(bool value);
  bool inc_in_sum_expr();
  uint get_in_sum_expr();
unknown's avatar
unknown committed
714

unknown's avatar
unknown committed
715 716
  bool add_item_to_list(THD *thd, Item *item);
  bool add_group_to_list(THD *thd, Item *item, bool asc);
717
  bool add_ftfunc_to_list(Item_func_match *func);
unknown's avatar
unknown committed
718
  bool add_order_to_list(THD *thd, Item *item, bool asc);
unknown's avatar
unknown committed
719
  TABLE_LIST* add_table_to_list(THD *thd, Table_ident *table,
720
				LEX_STRING *alias,
unknown's avatar
unknown committed
721
				ulong table_options,
722
				thr_lock_type flags= TL_UNLOCK,
unknown's avatar
unknown committed
723
				List<Index_hint> *hints= 0,
724
                                LEX_STRING *option= 0);
unknown's avatar
unknown committed
725
  TABLE_LIST* get_table_list();
726 727 728 729 730
  bool init_nested_join(THD *thd);
  TABLE_LIST *end_nested_join(THD *thd);
  TABLE_LIST *nest_last_join(THD *thd);
  void add_joined_table(TABLE_LIST *table);
  TABLE_LIST *convert_right_join();
unknown's avatar
unknown committed
731 732
  List<Item>* get_item_list();
  ulong get_table_join_options();
unknown's avatar
unknown committed
733
  void set_lock_for_tables(thr_lock_type lock_type);
734 735 736 737
  inline void init_order()
  {
    order_list.elements= 0;
    order_list.first= 0;
738
    order_list.next= (uchar**) &order_list.first;
739
  }
740 741 742 743 744 745 746
  /*
    This method created for reiniting LEX in mysql_admin_table() and can be
    used only if you are going remove all SELECT_LEX & units except belonger
    to LEX (LEX::unit & LEX::select, for other purposes there are
    SELECT_LEX_UNIT::exclude_level & SELECT_LEX_UNIT::exclude_tree
  */
  void cut_subtree() { slave= 0; }
unknown's avatar
unknown committed
747 748
  bool test_limit();

749
  friend void lex_start(THD *thd);
750
  st_select_lex() : n_sum_items(0), n_child_sum_items(0) {}
unknown's avatar
unknown committed
751
  void make_empty_select()
752 753 754 755
  {
    init_query();
    init_select();
  }
unknown's avatar
unknown committed
756
  bool setup_ref_array(THD *thd, uint order_group_num);
unknown's avatar
unknown committed
757 758 759
  void print(THD *thd, String *str);
  static void print_order(String *str, ORDER *order);
  void print_limit(THD *thd, String *str);
760
  void fix_prepare_information(THD *thd, Item **conds, Item **having_conds);
761 762 763 764 765
  /*
    Destroy the used execution plan (JOIN) of this subtree (this
    SELECT_LEX and all nested SELECT_LEXes and SELECT_LEX_UNITs).
  */
  bool cleanup();
766 767 768 769 770
  /*
    Recursively cleanup the join of this select lex and of all nested
    select lexes.
  */
  void cleanup_all_joins(bool full);
771 772 773 774 775 776 777 778 779 780 781 782

  void set_index_hint_type(enum index_hint_type type, index_clause_map clause);

  /* 
   Add a index hint to the tagged list of hints. The type and clause of the
   hint will be the current ones (set by set_index_hint()) 
  */
  bool add_index_hint (THD *thd, char *str, uint length);

  /* make a list to hold index hints */
  void alloc_index_hints (THD *thd);
  /* read and clear the index hints */
unknown's avatar
unknown committed
783
  List<Index_hint>* pop_index_hints(void) 
784
  {
unknown's avatar
unknown committed
785
    List<Index_hint> *hints= index_hints;
786 787 788 789 790 791 792 793 794 795 796
    index_hints= NULL;
    return hints;
  }

  void clear_index_hints(void) { index_hints= NULL; }

private:  
  /* current index hint kind. used in filling up index_hints */
  enum index_hint_type current_index_hint_type;
  index_clause_map current_index_hint_clause;
  /* a list of USE/FORCE/IGNORE INDEX */
unknown's avatar
unknown committed
797
  List<Index_hint> *index_hints;
unknown's avatar
unknown committed
798
};
unknown's avatar
unknown committed
799
typedef class st_select_lex SELECT_LEX;
800

unknown's avatar
unknown committed
801 802 803 804 805 806
inline bool st_select_lex_unit::is_union ()
{ 
  return first_select()->next_select() && 
    first_select()->next_select()->linkage == UNION_TYPE;
}

unknown's avatar
unknown committed
807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831
#define ALTER_ADD_COLUMN	(1L << 0)
#define ALTER_DROP_COLUMN	(1L << 1)
#define ALTER_CHANGE_COLUMN	(1L << 2)
#define ALTER_ADD_INDEX		(1L << 3)
#define ALTER_DROP_INDEX	(1L << 4)
#define ALTER_RENAME		(1L << 5)
#define ALTER_ORDER		(1L << 6)
#define ALTER_OPTIONS		(1L << 7)
#define ALTER_CHANGE_COLUMN_DEFAULT (1L << 8)
#define ALTER_KEYS_ONOFF        (1L << 9)
#define ALTER_CONVERT           (1L << 10)
#define ALTER_FORCE		(1L << 11)
#define ALTER_RECREATE          (1L << 12)
#define ALTER_ADD_PARTITION     (1L << 13)
#define ALTER_DROP_PARTITION    (1L << 14)
#define ALTER_COALESCE_PARTITION (1L << 15)
#define ALTER_REORGANIZE_PARTITION (1L << 16) 
#define ALTER_PARTITION          (1L << 17)
#define ALTER_OPTIMIZE_PARTITION (1L << 18)
#define ALTER_TABLE_REORG        (1L << 19)
#define ALTER_REBUILD_PARTITION  (1L << 20)
#define ALTER_ALL_PARTITION      (1L << 21)
#define ALTER_ANALYZE_PARTITION  (1L << 22)
#define ALTER_CHECK_PARTITION    (1L << 23)
#define ALTER_REPAIR_PARTITION   (1L << 24)
unknown's avatar
unknown committed
832
#define ALTER_REMOVE_PARTITIONING (1L << 25)
833
#define ALTER_FOREIGN_KEY         (1L << 26)
834

unknown's avatar
unknown committed
835 836 837 838 839 840 841
enum enum_alter_table_change_level
{
  ALTER_TABLE_METADATA_ONLY= 0,
  ALTER_TABLE_DATA_CHANGED= 1,
  ALTER_TABLE_INDEX_CHANGED= 2
};

842 843 844 845 846 847 848 849
/**
  @brief Parsing data for CREATE or ALTER TABLE.

  This structure contains a list of columns or indexes to be created,
  altered or dropped.
*/

class Alter_info
850
{
851
public:
unknown's avatar
unknown committed
852 853 854
  List<Alter_drop>              drop_list;
  List<Alter_column>            alter_list;
  List<Key>                     key_list;
unknown's avatar
unknown committed
855
  List<Create_field>            create_list;
unknown's avatar
unknown committed
856 857 858 859 860 861
  uint                          flags;
  enum enum_enable_or_disable   keys_onoff;
  enum tablespace_op_type       tablespace_op;
  List<char>                    partition_names;
  uint                          no_parts;
  enum_alter_table_change_level change_level;
unknown's avatar
unknown committed
862
  Create_field                 *datetime_field;
unknown's avatar
unknown committed
863 864
  bool                          error_if_not_empty;  
    
865

866 867 868 869
  Alter_info() :
    flags(0),
    keys_onoff(LEAVE_AS_IS),
    tablespace_op(NO_TABLESPACE_OP),
unknown's avatar
unknown committed
870 871 872 873
    no_parts(0),
    change_level(ALTER_TABLE_METADATA_ONLY),
    datetime_field(NULL),
    error_if_not_empty(FALSE)
874 875 876
  {}

  void reset()
unknown's avatar
unknown committed
877
  {
878 879 880 881 882
    drop_list.empty();
    alter_list.empty();
    key_list.empty();
    create_list.empty();
    flags= 0;
unknown's avatar
unknown committed
883 884 885 886
    keys_onoff= LEAVE_AS_IS;
    tablespace_op= NO_TABLESPACE_OP;
    no_parts= 0;
    partition_names.empty();
unknown's avatar
unknown committed
887 888 889
    change_level= ALTER_TABLE_METADATA_ONLY;
    datetime_field= 0;
    error_if_not_empty= FALSE;
unknown's avatar
unknown committed
890
  }
891 892 893 894 895 896 897 898 899 900 901 902 903 904 905
  /**
    Construct a copy of this object to be used for mysql_alter_table
    and mysql_create_table. Historically, these two functions modify
    their Alter_info arguments. This behaviour breaks re-execution of
    prepared statements and stored procedures and is compensated by
    always supplying a copy of Alter_info to these functions.

    @return You need to use check the error in THD for out
    of memory condition after calling this function.
  */
  Alter_info(const Alter_info &rhs, MEM_ROOT *mem_root);
private:
  Alter_info &operator=(const Alter_info &rhs); // not implemented
  Alter_info(const Alter_info &rhs);            // not implemented
};
906

907 908 909
struct st_sp_chistics
{
  LEX_STRING comment;
910
  enum enum_sp_suid_behaviour suid;
911
  bool detistic;
912
  enum enum_sp_data_access daccess;
913 914
};

915 916 917 918 919 920 921

struct st_trg_chistics
{
  enum trg_action_time_type action_time;
  enum trg_event_type event;
};

922
extern sys_var *trg_new_row_fake_var;
923

924 925 926
enum xa_option_words {XA_NONE, XA_JOIN, XA_RESUME, XA_ONE_PHASE,
                      XA_SUSPEND, XA_FOR_MIGRATE};

927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952

/*
  Class representing list of all tables used by statement.
  It also contains information about stored functions used by statement
  since during its execution we may have to add all tables used by its
  stored functions/triggers to this list in order to pre-open and lock
  them.

  Also used by st_lex::reset_n_backup/restore_backup_query_tables_list()
  methods to save and restore this information.
*/

class Query_tables_list
{
public:
  /* Global list of all tables used by this statement */
  TABLE_LIST *query_tables;
  /* Pointer to next_global member of last element in the previous list. */
  TABLE_LIST **query_tables_last;
  /*
    If non-0 then indicates that query requires prelocking and points to
    next_global member of last own element in query table list (i.e. last
    table which was not added to it as part of preparation to prelocking).
    0 - indicates that this query does not need prelocking.
  */
  TABLE_LIST **query_tables_own_last;
953 954 955 956 957
  /*
    Set of stored routines called by statement.
    (Note that we use lazy-initialization for this hash).
  */
  enum { START_SROUTINES_HASH_SIZE= 16 };
958 959 960 961 962 963 964 965 966 967 968
  HASH sroutines;
  /*
    List linking elements of 'sroutines' set. Allows you to add new elements
    to this set as you iterate through the list of existing elements.
    'sroutines_list_own_last' is pointer to ::next member of last element of
    this list which represents routine which is explicitly used by query.
    'sroutines_list_own_elements' number of explicitly used routines.
    We use these two members for restoring of 'sroutines_list' to the state
    in which it was right after query parsing.
  */
  SQL_LIST sroutines_list;
969
  uchar    **sroutines_list_own_last;
970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986
  uint     sroutines_list_own_elements;

  /*
    These constructor and destructor serve for creation/destruction
    of Query_tables_list instances which are used as backup storage.
  */
  Query_tables_list() {}
  ~Query_tables_list() {}

  /* Initializes (or resets) Query_tables_list object for "real" use. */
  void reset_query_tables_list(bool init);
  void destroy_query_tables_list();
  void set_query_tables_list(Query_tables_list *state)
  {
    *this= *state;
  }

unknown's avatar
unknown committed
987 988 989 990 991
  /*
    Direct addition to the list of query tables.
    If you are using this function, you must ensure that the table
    object, in particular table->db member, is initialized.
  */
992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018
  void add_to_query_tables(TABLE_LIST *table)
  {
    *(table->prev_global= query_tables_last)= table;
    query_tables_last= &table->next_global;
  }
  bool requires_prelocking()
  {
    return test(query_tables_own_last);
  }
  void mark_as_requiring_prelocking(TABLE_LIST **tables_own_last)
  {
    query_tables_own_last= tables_own_last;
  }
  /* Return pointer to first not-own table in query-tables or 0 */
  TABLE_LIST* first_not_own_table()
  {
    return ( query_tables_own_last ? *query_tables_own_last : 0);
  }
  void chop_off_not_own_tables()
  {
    if (query_tables_own_last)
    {
      *query_tables_own_last= 0;
      query_tables_last= query_tables_own_last;
      query_tables_own_last= 0;
    }
  }
1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040

  /**
     Has the parser/scanner detected that this statement is unsafe?
   */
  inline bool is_stmt_unsafe() const {
    return binlog_stmt_flags & (1U << BINLOG_STMT_FLAG_UNSAFE);
  }

  /**
     Flag the current (top-level) statement as unsafe.

     The flag will be reset after the statement has finished.

   */
  inline void set_stmt_unsafe() {
    binlog_stmt_flags|= (1U << BINLOG_STMT_FLAG_UNSAFE);
  }

  inline void clear_stmt_unsafe() {
    binlog_stmt_flags&= ~(1U << BINLOG_STMT_FLAG_UNSAFE);
  }

unknown's avatar
unknown committed
1041 1042 1043 1044 1045 1046
  /**
    true if the parsed tree contains references to stored procedures
    or functions, false otherwise
  */
  bool uses_stored_routines() const
  { return sroutines_list.elements != 0; }
1047

1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060
private:
  enum enum_binlog_stmt_flag {
    BINLOG_STMT_FLAG_UNSAFE,
    BINLOG_STMT_FLAG_COUNT
  };

  /*
    Tells if the parsing stage detected properties of the statement,
    for example: that some items require row-based binlogging to give
    a reliable binlog/replication, or if we will use stored functions
    or triggers which themselves need require row-based binlogging.
  */
  uint32 binlog_stmt_flags;
1061 1062 1063
};


1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075
/*
  st_parsing_options contains the flags for constructions that are
  allowed in the current statement.
*/

struct st_parsing_options
{
  bool allows_variable;
  bool allows_select_into;
  bool allows_select_procedure;
  bool allows_derived;

1076 1077
  st_parsing_options() { reset(); }
  void reset();
1078 1079 1080
};


1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104
/**
  The state of the lexical parser, when parsing comments.
*/
enum enum_comment_state
{
  /**
    Not parsing comments.
  */
  NO_COMMENT,
  /**
    Parsing comments that need to be preserved.
    Typically, these are user comments '/' '*' ... '*' '/'.
  */
  PRESERVE_COMMENT,
  /**
    Parsing comments that need to be discarded.
    Typically, these are special comments '/' '*' '!' ... '*' '/',
    or '/' '*' '!' 'M' 'M' 'm' 'm' 'm' ... '*' '/', where the comment
    markers should not be expanded.
  */
  DISCARD_COMMENT
};


1105 1106 1107
/**
  This class represents the character input stream consumed during
  lexical analysis.
1108 1109 1110 1111 1112 1113 1114 1115
  In addition to consuming the input stream, this class performs some
  comment pre processing, by filtering out out of bound special text
  from the query input stream.
  Two buffers, with pointers inside each buffers, are maintained in
  parallel. The 'raw' buffer is the original query text, which may
  contain out-of-bound comments. The 'cpp' (for comments pre processor)
  is the pre-processed buffer that contains only the query text that
  should be seen once out-of-bound data is removed.
1116 1117 1118 1119 1120 1121 1122
*/
class Lex_input_stream
{
public:
  Lex_input_stream(THD *thd, const char* buff, unsigned int length);
  ~Lex_input_stream();

1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175 1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239 1240 1241 1242
  /**
    Set the echo mode.
    When echo is true, characters parsed from the raw input stream are
    preserved. When false, characters parsed are silently ignored.
    @param echo the echo mode.
  */
  void set_echo(bool echo)
  {
    m_echo= echo;
  }

  /**
    Skip binary from the input stream.
    @param n number of bytes to accept.
  */
  void skip_binary(int n)
  {
    if (m_echo)
    {
      memcpy(m_cpp_ptr, m_ptr, n);
      m_cpp_ptr += n;
    }
    m_ptr += n;
  }

  /**
    Get a character, and advance in the stream.
    @return the next character to parse.
  */
  char yyGet()
  {
    char c= *m_ptr++;
    if (m_echo)
      *m_cpp_ptr++ = c;
    return c;
  }

  /**
    Get the last character accepted.
    @return the last character accepted.
  */
  char yyGetLast()
  {
    return m_ptr[-1];
  }

  /**
    Look at the next character to parse, but do not accept it.
  */
  char yyPeek()
  {
    return m_ptr[0];
  }

  /**
    Look ahead at some character to parse.
    @param n offset of the character to look up
  */
  char yyPeekn(int n)
  {
    return m_ptr[n];
  }

  /**
    Cancel the effect of the last yyGet() or yySkip().
    Note that the echo mode should not change between calls to yyGet / yySkip
    and yyUnget. The caller is responsible for ensuring that.
  */
  void yyUnget()
  {
    m_ptr--;
    if (m_echo)
      m_cpp_ptr--;
  }

  /**
    Accept a character, by advancing the input stream.
  */
  void yySkip()
  {
    if (m_echo)
      *m_cpp_ptr++ = *m_ptr++;
    else
      m_ptr++;
  }

  /**
    Accept multiple characters at once.
    @param n the number of characters to accept.
  */
  void yySkipn(int n)
  {
    if (m_echo)
    {
      memcpy(m_cpp_ptr, m_ptr, n);
      m_cpp_ptr += n;
    }
    m_ptr += n;
  }

  /**
    End of file indicator for the query text to parse.
    @return true if there are no more characters to parse
  */
  bool eof()
  {
    return (m_ptr >= m_end_of_query);
  }

  /**
    End of file indicator for the query text to parse.
    @param n number of characters expected
    @return true if there are less than n characters to parse
  */
  bool eof(int n)
  {
    return ((m_ptr + n) >= m_end_of_query);
  }

  /** Get the raw query buffer. */
unknown's avatar
unknown committed
1243
  const char *get_buf()
1244 1245 1246 1247 1248
  {
    return m_buf;
  }

  /** Get the pre-processed query buffer. */
unknown's avatar
unknown committed
1249
  const char *get_cpp_buf()
1250 1251 1252 1253 1254
  {
    return m_cpp_buf;
  }

  /** Get the end of the raw query buffer. */
unknown's avatar
unknown committed
1255
  const char *get_end_of_query()
1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282
  {
    return m_end_of_query;
  }

  /** Mark the stream position as the start of a new token. */
  void start_token()
  {
    m_tok_start_prev= m_tok_start;
    m_tok_start= m_ptr;
    m_tok_end= m_ptr;

    m_cpp_tok_start_prev= m_cpp_tok_start;
    m_cpp_tok_start= m_cpp_ptr;
    m_cpp_tok_end= m_cpp_ptr;
  }

  /**
    Adjust the starting position of the current token.
    This is used to compensate for starting whitespace.
  */
  void restart_token()
  {
    m_tok_start= m_ptr;
    m_cpp_tok_start= m_cpp_ptr;
  }

  /** Get the token start position, in the raw buffer. */
unknown's avatar
unknown committed
1283
  const char *get_tok_start()
1284 1285 1286 1287 1288
  {
    return m_tok_start;
  }

  /** Get the token start position, in the pre-processed buffer. */
unknown's avatar
unknown committed
1289
  const char *get_cpp_tok_start()
1290 1291 1292 1293 1294
  {
    return m_cpp_tok_start;
  }

  /** Get the token end position, in the raw buffer. */
unknown's avatar
unknown committed
1295
  const char *get_tok_end()
1296 1297 1298 1299 1300
  {
    return m_tok_end;
  }

  /** Get the token end position, in the pre-processed buffer. */
unknown's avatar
unknown committed
1301
  const char *get_cpp_tok_end()
1302 1303 1304 1305 1306
  {
    return m_cpp_tok_end;
  }

  /** Get the previous token start position, in the raw buffer. */
unknown's avatar
unknown committed
1307
  const char *get_tok_start_prev()
1308 1309 1310 1311 1312
  {
    return m_tok_start_prev;
  }

  /** Get the current stream pointer, in the raw buffer. */
unknown's avatar
unknown committed
1313
  const char *get_ptr()
1314 1315 1316 1317 1318
  {
    return m_ptr;
  }

  /** Get the current stream pointer, in the pre-processed buffer. */
unknown's avatar
unknown committed
1319
  const char *get_cpp_ptr()
1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334
  {
    return m_cpp_ptr;
  }

  /** Get the length of the current token, in the raw buffer. */
  uint yyLength()
  {
    /*
      The assumption is that the lexical analyser is always 1 character ahead,
      which the -1 account for.
    */
    DBUG_ASSERT(m_ptr > m_tok_start);
    return (uint) ((m_ptr - m_tok_start) - 1);
  }

unknown's avatar
unknown committed
1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354
  /** Get the utf8-body string. */
  const char *get_body_utf8_str()
  {
    return m_body_utf8;
  }

  /** Get the utf8-body length. */
  uint get_body_utf8_length()
  {
    return m_body_utf8_ptr - m_body_utf8;
  }

  void body_utf8_start(THD *thd, const char *begin_ptr);
  void body_utf8_append(const char *ptr);
  void body_utf8_append(const char *ptr, const char *end_ptr);
  void body_utf8_append_literal(THD *thd,
                                const LEX_STRING *txt,
                                CHARSET_INFO *txt_cs,
                                const char *end_ptr);

1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366
  /** Current thread. */
  THD *m_thd;

  /** Current line number. */
  uint yylineno;

  /** Length of the last token parsed. */
  uint yytoklen;

  /** Interface with bison, value of the last token parsed. */
  LEX_YYSTYPE yylval;

1367 1368
private:
  /** Pointer to the current position in the raw input stream. */
unknown's avatar
unknown committed
1369
  const char *m_ptr;
1370 1371

  /** Starting position of the last token parsed, in the raw buffer. */
unknown's avatar
unknown committed
1372
  const char *m_tok_start;
1373

1374
  /** Ending position of the previous token parsed, in the raw buffer. */
unknown's avatar
unknown committed
1375
  const char *m_tok_end;
1376

1377
  /** End of the query text in the input stream, in the raw buffer. */
unknown's avatar
unknown committed
1378
  const char *m_end_of_query;
1379

1380
  /** Starting position of the previous token parsed, in the raw buffer. */
unknown's avatar
unknown committed
1381
  const char *m_tok_start_prev;
1382

1383
  /** Begining of the query text in the input stream, in the raw buffer. */
unknown's avatar
unknown committed
1384
  const char *m_buf;
1385

unknown's avatar
unknown committed
1386 1387 1388
  /** Length of the raw buffer. */
  uint m_buf_length;

1389 1390 1391 1392
  /** Echo the parsed stream to the pre-processed buffer. */
  bool m_echo;

  /** Pre-processed buffer. */
unknown's avatar
unknown committed
1393
  char *m_cpp_buf;
1394 1395

  /** Pointer to the current position in the pre-processed input stream. */
unknown's avatar
unknown committed
1396
  char *m_cpp_ptr;
1397 1398 1399 1400 1401

  /**
    Starting position of the last token parsed,
    in the pre-processed buffer.
  */
unknown's avatar
unknown committed
1402
  const char *m_cpp_tok_start;
1403 1404 1405 1406 1407

  /**
    Starting position of the previous token parsed,
    in the pre-procedded buffer.
  */
unknown's avatar
unknown committed
1408
  const char *m_cpp_tok_start_prev;
1409 1410 1411 1412 1413

  /**
    Ending position of the previous token parsed,
    in the pre-processed buffer.
  */
unknown's avatar
unknown committed
1414
  const char *m_cpp_tok_end;
1415

unknown's avatar
unknown committed
1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427
  /** UTF8-body buffer created during parsing. */
  char *m_body_utf8;

  /** Pointer to the current position in the UTF8-body buffer. */
  char *m_body_utf8_ptr;

  /**
    Position in the pre-processed buffer. The query from m_cpp_buf to
    m_cpp_utf_processed_ptr is converted to UTF8-body.
  */
  const char *m_cpp_utf8_processed_ptr;

1428
public:
1429 1430 1431 1432

  /** Current state of the lexical analyser. */
  enum my_lex_states next_state;

1433 1434 1435 1436
  /**
    Position of ';' in the stream, to delimit multiple queries.
    This delimiter is in the raw buffer.
  */
unknown's avatar
unknown committed
1437
  const char *found_semicolon;
1438

1439 1440
  /** Token character bitmaps, to detect 7bit strings. */
  uchar tok_bitmap;
unknown's avatar
unknown committed
1441

1442 1443
  /** SQL_MODE = IGNORE_SPACE. */
  bool ignore_space;
1444 1445

  /**
1446 1447 1448 1449
    TRUE if we're parsing a prepared statement: in this mode
    we should allow placeholders and disallow multi-statements.
  */
  bool stmt_prepare_mode;
1450 1451 1452

  /** State of the lexical analyser for comments. */
  enum_comment_state in_comment;
unknown's avatar
unknown committed
1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475

  /**
    Starting position of the TEXT_STRING or IDENT in the pre-processed
    buffer.

    NOTE: this member must be used within MYSQLlex() function only.
  */
  const char *m_cpp_text_start;

  /**
    Ending position of the TEXT_STRING or IDENT in the pre-processed
    buffer.

    NOTE: this member must be used within MYSQLlex() function only.
    */
  const char *m_cpp_text_end;

  /**
    Character set specified by the character-set-introducer.

    NOTE: this member must be used within MYSQLlex() function only.
  */
  CHARSET_INFO *m_underscore_cs;
1476 1477 1478
};


unknown's avatar
unknown committed
1479 1480
/* The state of the lex parsing. This is saved in the THD struct */

1481
typedef struct st_lex : public Query_tables_list
1482
{
unknown's avatar
unknown committed
1483
  SELECT_LEX_UNIT unit;                         /* most upper unit */
1484 1485
  SELECT_LEX select_lex;                        /* first SELECT_LEX */
  /* current SELECT_LEX in parsing */
unknown's avatar
unknown committed
1486
  SELECT_LEX *current_select;
1487 1488
  /* list of all SELECT_LEX */
  SELECT_LEX *all_selects_list;
1489

1490 1491
  char *length,*dec,*change;
  LEX_STRING name;
unknown's avatar
unknown committed
1492
  char *help_arg;
1493
  char *backup_dir;				/* For RESTORE/BACKUP */
unknown's avatar
unknown committed
1494
  char* to_log;                                 /* For PURGE MASTER LOGS TO */
1495
  char* x509_subject,*x509_issuer,*ssl_cipher;
unknown's avatar
unknown committed
1496 1497
  String *wild;
  sql_exchange *exchange;
1498
  select_result *result;
1499
  Item *default_value, *on_update_value;
1500
  LEX_STRING comment, ident;
unknown's avatar
unknown committed
1501
  LEX_USER *grant_user;
unknown's avatar
unknown committed
1502
  XID *xid;
1503
  uchar* yacc_yyss, *yacc_yyvs;
unknown's avatar
unknown committed
1504
  THD *thd;
unknown's avatar
unknown committed
1505 1506 1507 1508

  /* maintain a list of used plugins for this LEX */
  DYNAMIC_ARRAY plugins;
  plugin_ref plugins_static_buffer[INITIAL_LEX_PLUGIN_LIST_SIZE];
1509

unknown's avatar
unknown committed
1510
  CHARSET_INFO *charset;
1511
  bool text_string_is_7bit;
1512 1513
  /* store original leaf_tables for INSERT SELECT and PS/SP */
  TABLE_LIST *leaf_tables_insert;
1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524

  /** Start of SELECT of CREATE VIEW statement */
  const char* create_view_select_start;
  /** End of SELECT of CREATE VIEW statement */
  const char* create_view_select_end;

  /** Start of 'ON <table>', in trigger statements.  */
  const char* raw_trg_on_table_name_begin;
  /** End of 'ON <table>', in trigger statements. */
  const char* raw_trg_on_table_name_end;

1525 1526
  /* Partition info structure filled in by PARTITION BY parse part */
  partition_info *part_info;
unknown's avatar
unknown committed
1527

1528 1529 1530 1531 1532 1533
  /*
    The definer of the object being created (view, trigger, stored routine).
    I.e. the value of DEFINER clause.
  */
  LEX_USER *definer;

unknown's avatar
unknown committed
1534 1535
  List<Key_part_spec> col_list;
  List<Key_part_spec> ref_list;
1536
  List<String>	      interval_list;
unknown's avatar
unknown committed
1537
  List<LEX_USER>      users_list;
unknown's avatar
unknown committed
1538
  List<LEX_COLUMN>    columns;
unknown's avatar
unknown committed
1539
  List<Item>	      *insert_list,field_list,value_list,update_list;
1540
  List<List_item>     many_values;
unknown's avatar
unknown committed
1541
  List<set_var_base>  var_list;
1542
  List<Item_param>    param_list;
unknown's avatar
VIEW  
unknown committed
1543
  List<LEX_STRING>    view_list; // view list (list of field names in view)
unknown's avatar
unknown committed
1544 1545 1546 1547 1548 1549 1550 1551 1552 1553 1554 1555 1556 1557
  /*
    A stack of name resolution contexts for the query. This stack is used
    at parse time to set local name resolution contexts for various parts
    of a query. For example, in a JOIN ... ON (some_condition) clause the
    Items in 'some_condition' must be resolved only against the operands
    of the the join, and not against the whole clause. Similarly, Items in
    subqueries should be resolved against the subqueries (and outer queries).
    The stack is used in the following way: when the parser detects that
    all Items in some clause need a local context, it creates a new context
    and pushes it on the stack. All newly created Items always store the
    top-most context in the stack. Once the parser leaves the clause that
    required a local context, the parser pops the top-most context.
  */
  List<Name_resolution_context> context_stack;
unknown's avatar
unknown committed
1558
  List<LEX_STRING>     db_list;
unknown's avatar
unknown committed
1559

unknown's avatar
unknown committed
1560
  SQL_LIST	      proc_list, auxiliary_table_list, save_list;
unknown's avatar
unknown committed
1561
  Create_field	      *last_field;
unknown's avatar
unknown committed
1562
  Item_sum *in_sum_func;
unknown's avatar
unknown committed
1563
  udf_func udf;
1564 1565
  HA_CHECK_OPT   check_opt;			// check/repair options
  HA_CREATE_INFO create_info;
unknown's avatar
unknown committed
1566
  KEY_CREATE_INFO key_create_info;
unknown's avatar
unknown committed
1567
  LEX_MASTER_INFO mi;				// used by CHANGE MASTER
unknown's avatar
unknown committed
1568
  LEX_SERVER_OPTIONS server_options;
1569
  USER_RESOURCES mqh;
1570
  ulong type;
unknown's avatar
unknown committed
1571 1572 1573 1574 1575 1576 1577 1578 1579 1580
  /*
    This variable is used in post-parse stage to declare that sum-functions,
    or functions which have sense only if GROUP BY is present, are allowed.
    For example in a query
    SELECT ... FROM ...WHERE MIN(i) == 1 GROUP BY ... HAVING MIN(i) > 2
    MIN(i) in the WHERE clause is not allowed in the opposite to MIN(i)
    in the HAVING clause. Due to possible nesting of select construct
    the variable can contain 0 or 1 for each nest level.
  */
  nesting_map allow_sum_func;
1581
  enum_sql_command sql_command;
1582 1583 1584 1585 1586 1587 1588 1589
  /*
    Usually `expr` rule of yacc is quite reused but some commands better
    not support subqueries which comes standard with this rule, like
    KILL, HA_READ, CREATE/ALTER EVENT etc. Set this to `false` to get
    syntax error back.
  */
  bool expr_allows_subselect;

1590
  thr_lock_type lock_option;
unknown's avatar
unknown committed
1591
  enum SSL_type ssl_type;			/* defined in violite.h */
1592
  enum enum_duplicates duplicates;
unknown's avatar
unknown committed
1593
  enum enum_tx_isolation tx_isolation;
1594
  enum enum_ha_read_modes ha_read_mode;
1595
  union {
unknown's avatar
unknown committed
1596
    enum ha_rkey_function ha_rkey_mode;
1597 1598
    enum xa_option_words xa_opt;
  };
unknown's avatar
unknown committed
1599
  enum enum_var_type option_type;
unknown's avatar
VIEW  
unknown committed
1600 1601
  enum enum_view_create_mode create_view_mode;
  enum enum_drop_mode drop_mode;
unknown's avatar
unknown committed
1602
  uint uint_geom_type;
unknown's avatar
unknown committed
1603
  uint grant, grant_tot_col, which_columns;
1604
  uint fk_delete_opt, fk_update_opt, fk_match_option;
1605
  uint slave_thd_opt, start_transaction_opt;
unknown's avatar
unknown committed
1606
  int nest_level;
1607 1608 1609 1610 1611 1612
  /*
    In LEX representing update which were transformed to multi-update
    stores total number of tables. For LEX representing multi-delete
    holds number of tables from which we will delete records.
  */
  uint table_count;
unknown's avatar
unknown committed
1613
  uint8 describe;
1614 1615 1616
  /*
    A flag that indicates what kinds of derived tables are present in the
    query (0 if no derived tables, otherwise a combination of flags
unknown's avatar
unknown committed
1617
    DERIVED_SUBQUERY and DERIVED_VIEW).
1618
  */
unknown's avatar
VIEW  
unknown committed
1619 1620
  uint8 derived_tables;
  uint8 create_view_algorithm;
unknown's avatar
unknown committed
1621
  uint8 create_view_check;
1622
  bool drop_if_exists, drop_temporary, local_file, one_shot_set;
1623 1624 1625

  bool verbose, no_write_to_binlog;

unknown's avatar
unknown committed
1626
  bool tx_chain, tx_release;
unknown's avatar
unknown committed
1627 1628 1629 1630 1631 1632 1633
  /*
    Special JOIN::prepare mode: changing of query is prohibited.
    When creating a view, we need to just check its syntax omitting
    any optimizations: afterwards definition of the view will be
    reconstructed by means of ::print() methods and written to
    to an .frm file. We need this definition to stay untouched.
  */
unknown's avatar
VIEW  
unknown committed
1634
  bool view_prepare_mode;
1635
  bool safe_to_cache_query;
1636
  bool subqueries, ignore;
1637
  st_parsing_options parsing_options;
1638
  Alter_info alter_info;
unknown's avatar
unknown committed
1639 1640
  /* Prepared statements SQL syntax:*/
  LEX_STRING prepared_stmt_name; /* Statement name (in all queries) */
unknown's avatar
unknown committed
1641
  /*
1642 1643 1644
    Prepared statement query text or name of variable that holds the
    prepared statement (in PREPARE ... queries)
  */
unknown's avatar
unknown committed
1645
  LEX_STRING prepared_stmt_code;
1646 1647
  /* If true, prepared_stmt_code is a name of variable that holds the query */
  bool prepared_stmt_code_is_varref;
unknown's avatar
unknown committed
1648
  /* Names of user variables holding parameters (in EXECUTE) */
unknown's avatar
unknown committed
1649
  List<LEX_STRING> prepared_stmt_params;
1650
  sp_head *sphead;
1651
  sp_name *spname;
1652
  bool sp_lex_in_use;	/* Keep track on lex usage in SPs for error handling */
1653
  bool all_privileges;
1654
  sp_pcontext *spcont;
1655

1656
  st_sp_chistics sp_chistics;
1657

1658
  Event_parse_data *event_parse_data;
1659

unknown's avatar
VIEW  
unknown committed
1660 1661 1662 1663 1664 1665
  bool only_view;       /* used for SHOW CREATE TABLE/VIEW */
  /*
    field_list was created for view and should be removed before PS/SP
    rexecuton
  */
  bool empty_field_list_on_rset;
1666 1667 1668
  /*
    view created to be run from definer (standard behaviour)
  */
1669
  uint8 create_view_suid;
1670 1671 1672
  /* Characterstics of trigger being created */
  st_trg_chistics trg_chistics;
  /*
1673 1674 1675 1676 1677
    List of all items (Item_trigger_field objects) representing fields in
    old/new version of row in trigger. We use this list for checking whenever
    all such fields are valid at trigger creation time and for binding these
    fields to TABLE object at table open (altough for latter pointer to table
    being opened is probably enough).
1678
  */
1679
  SQL_LIST trg_table_fields;
1680

1681
  /*
1682 1683 1684 1685 1686 1687 1688
    stmt_definition_begin is intended to point to the next word after
    DEFINER-clause in the following statements:
      - CREATE TRIGGER (points to "TRIGGER");
      - CREATE PROCEDURE (points to "PROCEDURE");
      - CREATE FUNCTION (points to "FUNCTION" or "AGGREGATE");

    This pointer is required to add possibly omitted DEFINER-clause to the
1689
    DDL-statement before dumping it to the binlog.
1690
  */
1691
  const char *stmt_definition_begin;
1692

1693 1694
  const char *stmt_definition_end;

unknown's avatar
unknown committed
1695 1696 1697 1698
  /*
    Pointers to part of LOAD DATA statement that should be rewritten
    during replication ("LOCAL 'filename' REPLACE INTO" part).
  */
1699 1700
  const char *fname_start;
  const char *fname_end;
unknown's avatar
unknown committed
1701

unknown's avatar
unknown committed
1702 1703
  LEX_STRING view_body_utf8;

unknown's avatar
unknown committed
1704 1705 1706 1707 1708
  /*
    Reference to a struct that contains information in various commands
    to add/create/drop/change table spaces.
  */
  st_alter_tablespace *alter_tablespace_info;
1709 1710
  
  bool escape_used;
unknown's avatar
unknown committed
1711

1712
  st_lex();
1713 1714

  virtual ~st_lex()
1715
  {
1716
    destroy_query_tables_list();
unknown's avatar
unknown committed
1717 1718
    plugin_unlock_list(NULL, (plugin_ref *)plugins.buffer, plugins.elements);
    delete_dynamic(&plugins);
1719
  }
1720

1721
  inline void uncacheable(uint8 cause)
1722 1723
  {
    safe_to_cache_query= 0;
1724 1725 1726 1727 1728 1729

    /*
      There are no sense to mark select_lex and union fields of LEX,
      but we should merk all subselects as uncacheable from current till
      most upper
    */
unknown's avatar
unknown committed
1730
    SELECT_LEX *sl;
unknown's avatar
unknown committed
1731 1732 1733 1734
    SELECT_LEX_UNIT *un;
    for (sl= current_select, un= sl->master_unit();
	 un != &unit;
	 sl= sl->outer_select(), un= sl->master_unit())
1735
    {
1736 1737
      sl->uncacheable|= cause;
      un->uncacheable|= cause;
1738
    }
1739
  }
1740 1741
  void set_trg_event_type_for_tables();

unknown's avatar
VIEW  
unknown committed
1742 1743 1744 1745 1746 1747
  TABLE_LIST *unlink_first_table(bool *link_to_local);
  void link_first_table_back(TABLE_LIST *first, bool link_to_local);
  void first_lists_tables_same();

  bool can_be_merged();
  bool can_use_merged();
1748
  bool can_not_use_merged();
unknown's avatar
VIEW  
unknown committed
1749
  bool only_view_structure();
unknown's avatar
unknown committed
1750
  bool need_correct_ident();
1751
  uint8 get_effective_with_check(TABLE_LIST *view);
1752 1753
  /*
    Is this update command where 'WHITH CHECK OPTION' clause is important
1754

1755 1756 1757 1758 1759 1760 1761 1762 1763 1764 1765 1766 1767 1768
    SYNOPSIS
      st_lex::which_check_option_applicable()

    RETURN
      TRUE   have to take 'WHITH CHECK OPTION' clause into account
      FALSE  'WHITH CHECK OPTION' clause do not need
  */
  inline bool which_check_option_applicable()
  {
    switch (sql_command) {
    case SQLCOM_UPDATE:
    case SQLCOM_UPDATE_MULTI:
    case SQLCOM_INSERT:
    case SQLCOM_INSERT_SELECT:
1769 1770
    case SQLCOM_REPLACE:
    case SQLCOM_REPLACE_SELECT:
1771 1772 1773 1774 1775 1776
    case SQLCOM_LOAD:
      return TRUE;
    default:
      return FALSE;
    }
  }
1777

1778
  void cleanup_after_one_table_open();
unknown's avatar
unknown committed
1779

1780
  bool push_context(Name_resolution_context *context)
unknown's avatar
unknown committed
1781
  {
1782
    return context_stack.push_front(context);
unknown's avatar
unknown committed
1783 1784 1785 1786 1787 1788 1789
  }

  void pop_context()
  {
    context_stack.pop();
  }

1790
  bool copy_db_to(char **p_db, size_t *p_db_length) const;
1791

unknown's avatar
unknown committed
1792 1793 1794 1795
  Name_resolution_context *current_context()
  {
    return context_stack.head();
  }
1796 1797 1798 1799
  /*
    Restore the LEX and THD in case of a parse error.
  */
  static void cleanup_lex_after_parse_error(THD *thd);
1800 1801 1802

  void reset_n_backup_query_tables_list(Query_tables_list *backup);
  void restore_backup_query_tables_list(Query_tables_list *backup);
unknown's avatar
unknown committed
1803 1804

  bool table_or_sp_used();
1805
  bool is_partition_management() const;
unknown's avatar
unknown committed
1806 1807
} LEX;

unknown's avatar
unknown committed
1808 1809 1810 1811
struct st_lex_local: public st_lex
{
  static void *operator new(size_t size)
  {
1812
    return sql_alloc(size);
unknown's avatar
unknown committed
1813 1814 1815 1816 1817
  }
  static void *operator new(size_t size, MEM_ROOT *mem_root)
  {
    return (void*) alloc_root(mem_root, (uint) size);
  }
unknown's avatar
unknown committed
1818 1819
  static void operator delete(void *ptr,size_t size)
  { TRASH(ptr, size); }
1820 1821
  static void operator delete(void *ptr, MEM_ROOT *mem_root)
  { /* Never called */ }
unknown's avatar
unknown committed
1822
};
unknown's avatar
unknown committed
1823

unknown's avatar
unknown committed
1824 1825
extern void lex_init(void);
extern void lex_free(void);
1826
extern void lex_start(THD *thd);
unknown's avatar
unknown committed
1827
extern void lex_end(LEX *lex);
1828
extern int MYSQLlex(void *arg, void *yythd);
1829 1830

extern void trim_whitespace(CHARSET_INFO *cs, LEX_STRING *str);
unknown's avatar
unknown committed
1831

1832 1833
extern bool is_lex_native_function(const LEX_STRING *name);

1834
#endif /* MYSQL_SERVER */