item.h 113 KB
Newer Older
1 2 3
#ifndef ITEM_INCLUDED
#define ITEM_INCLUDED

4
/* Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.
unknown's avatar
unknown committed
5

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

unknown's avatar
unknown committed
10 11 12 13
   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
14

unknown's avatar
unknown committed
15 16 17 18 19
   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 */


20
#ifdef USE_PRAGMA_INTERFACE
unknown's avatar
unknown committed
21 22 23
#pragma interface			/* gcc class implementation */
#endif

24 25 26 27 28 29 30
#include "sql_priv.h"                /* STRING_BUFFER_USUAL_SIZE */
#include "unireg.h"
#include "sql_const.h"                 /* RAND_TABLE_BIT, MAX_FIELD_NAME */
#include "unireg.h"                    // REQUIRED: for other includes
#include "thr_malloc.h"                         /* sql_calloc */
#include "field.h"                              /* Derivation */

31
class Protocol;
32
struct TABLE_LIST;
unknown's avatar
unknown committed
33
void item_init(void);			/* Init item functions */
34
class Item_field;
35
class user_var_entry;
unknown's avatar
unknown committed
36

37 38 39 40 41 42 43 44 45

static inline uint32
char_to_byte_length_safe(uint32 char_length_arg, uint32 mbmaxlen_arg)
{
   ulonglong tmp= ((ulonglong) char_length_arg) * mbmaxlen_arg;
   return (tmp > UINT_MAX32) ? (uint32) UINT_MAX32 : (uint32) tmp;
}


46 47
/*
   "Declared Type Collation"
unknown's avatar
unknown committed
48
   A combination of collation and its derivation.
49

50
  Flags for collation aggregation modes:
unknown's avatar
unknown committed
51 52 53 54
  MY_COLL_ALLOW_SUPERSET_CONV  - allow conversion to a superset
  MY_COLL_ALLOW_COERCIBLE_CONV - allow conversion of a coercible value
                                 (i.e. constant).
  MY_COLL_ALLOW_CONV           - allow any kind of conversion
unknown's avatar
unknown committed
55
                                 (combination of the above two)
unknown's avatar
unknown committed
56 57 58 59
  MY_COLL_DISALLOW_NONE        - don't allow return DERIVATION_NONE
                                 (e.g. when aggregating for comparison)
  MY_COLL_CMP_CONV             - combination of MY_COLL_ALLOW_CONV
                                 and MY_COLL_DISALLOW_NONE
60 61 62 63
*/

#define MY_COLL_ALLOW_SUPERSET_CONV   1
#define MY_COLL_ALLOW_COERCIBLE_CONV  2
unknown's avatar
unknown committed
64
#define MY_COLL_DISALLOW_NONE         4
65 66 67

#define MY_COLL_ALLOW_CONV (MY_COLL_ALLOW_SUPERSET_CONV | MY_COLL_ALLOW_COERCIBLE_CONV)
#define MY_COLL_CMP_CONV   (MY_COLL_ALLOW_CONV | MY_COLL_DISALLOW_NONE)
68

69 70 71 72
class DTCollation {
public:
  CHARSET_INFO     *collation;
  enum Derivation derivation;
73
  uint repertoire;
74
  
75 76 77 78 79
  void set_repertoire_from_charset(CHARSET_INFO *cs)
  {
    repertoire= cs->state & MY_CS_PUREASCII ?
                MY_REPERTOIRE_ASCII : MY_REPERTOIRE_UNICODE30;
  }
80 81 82 83
  DTCollation()
  {
    collation= &my_charset_bin;
    derivation= DERIVATION_NONE;
84
    repertoire= MY_REPERTOIRE_UNICODE30;
85 86 87 88 89
  }
  DTCollation(CHARSET_INFO *collation_arg, Derivation derivation_arg)
  {
    collation= collation_arg;
    derivation= derivation_arg;
90
    set_repertoire_from_charset(collation_arg);
91
  }
92
  void set(DTCollation &dt)
93
  { 
94 95
    collation= dt.collation;
    derivation= dt.derivation;
96
    repertoire= dt.repertoire;
97 98 99 100 101
  }
  void set(CHARSET_INFO *collation_arg, Derivation derivation_arg)
  {
    collation= collation_arg;
    derivation= derivation_arg;
102 103 104 105 106 107 108 109 110
    set_repertoire_from_charset(collation_arg);
  }
  void set(CHARSET_INFO *collation_arg,
           Derivation derivation_arg,
           uint repertoire_arg)
  {
    collation= collation_arg;
    derivation= derivation_arg;
    repertoire= repertoire_arg;
111
  }
112 113 114 115 116 117
  void set_numeric()
  {
    collation= &my_charset_numeric;
    derivation= DERIVATION_NUMERIC;
    repertoire= MY_REPERTOIRE_NUMERIC;
  }
118
  void set(CHARSET_INFO *collation_arg)
119 120 121 122
  {
    collation= collation_arg;
    set_repertoire_from_charset(collation_arg);
  }
123 124
  void set(Derivation derivation_arg)
  { derivation= derivation_arg; }
125 126 127
  bool aggregate(DTCollation &dt, uint flags= 0);
  bool set(DTCollation &dt1, DTCollation &dt2, uint flags= 0)
  { set(dt1); return aggregate(dt2, flags); }
128 129 130 131
  const char *derivation_name() const
  {
    switch(derivation)
    {
132
      case DERIVATION_NUMERIC:   return "NUMERIC";
133
      case DERIVATION_IGNORABLE: return "IGNORABLE";
134 135
      case DERIVATION_COERCIBLE: return "COERCIBLE";
      case DERIVATION_IMPLICIT:  return "IMPLICIT";
136
      case DERIVATION_SYSCONST:  return "SYSCONST";
137 138 139 140 141 142 143
      case DERIVATION_EXPLICIT:  return "EXPLICIT";
      case DERIVATION_NONE:      return "NONE";
      default: return "UNKNOWN";
    }
  }
};

144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196
/*************************************************************************/
/*
  A framework to easily handle different return types for hybrid items
  (hybrid item is an item whose operand can be of any type, e.g. integer,
  real, decimal).
*/

struct Hybrid_type_traits;

struct Hybrid_type
{
  longlong integer;

  double real;
  /*
    Use two decimal buffers interchangeably to speed up += operation
    which has no native support in decimal library.
    Hybrid_type+= arg is implemented as dec_buf[1]= dec_buf[0] + arg.
    The third decimal is used as a handy temporary storage.
  */
  my_decimal dec_buf[3];
  int used_dec_buf_no;

  /*
    Traits moved to a separate class to
      a) be able to easily change object traits in runtime
      b) they work as a differentiator for the union above
  */
  const Hybrid_type_traits *traits;

  Hybrid_type() {}
  /* XXX: add traits->copy() when needed */
  Hybrid_type(const Hybrid_type &rhs) :traits(rhs.traits) {}
};


/* Hybryd_type_traits interface + default implementation for REAL_RESULT */

struct Hybrid_type_traits
{
  virtual Item_result type() const { return REAL_RESULT; }

  virtual void
  fix_length_and_dec(Item *item, Item *arg) const;

  /* Hybrid_type operations. */
  virtual void set_zero(Hybrid_type *val) const { val->real= 0.0; }
  virtual void add(Hybrid_type *val, Field *f) const
  { val->real+= f->val_real(); }
  virtual void div(Hybrid_type *val, ulonglong u) const
  { val->real/= ulonglong2double(u); }

  virtual longlong val_int(Hybrid_type *val, bool unsigned_flag) const
197
  { return (longlong) rint(val->real); }
198 199 200 201
  virtual double val_real(Hybrid_type *val) const { return val->real; }
  virtual my_decimal *val_decimal(Hybrid_type *val, my_decimal *buf) const;
  virtual String *val_str(Hybrid_type *val, String *buf, uint8 decimals) const;
  static const Hybrid_type_traits *instance();
202 203
  Hybrid_type_traits() {}
  virtual ~Hybrid_type_traits() {}
204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224
};


struct Hybrid_type_traits_decimal: public Hybrid_type_traits
{
  virtual Item_result type() const { return DECIMAL_RESULT; }

  virtual void
  fix_length_and_dec(Item *arg, Item *item) const;

  /* Hybrid_type operations. */
  virtual void set_zero(Hybrid_type *val) const;
  virtual void add(Hybrid_type *val, Field *f) const;
  virtual void div(Hybrid_type *val, ulonglong u) const;

  virtual longlong val_int(Hybrid_type *val, bool unsigned_flag) const;
  virtual double val_real(Hybrid_type *val) const;
  virtual my_decimal *val_decimal(Hybrid_type *val, my_decimal *buf) const
  { return &val->dec_buf[val->used_dec_buf_no]; }
  virtual String *val_str(Hybrid_type *val, String *buf, uint8 decimals) const;
  static const Hybrid_type_traits_decimal *instance();
225
  Hybrid_type_traits_decimal() {};
226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255
};


struct Hybrid_type_traits_integer: public Hybrid_type_traits
{
  virtual Item_result type() const { return INT_RESULT; }

  virtual void
  fix_length_and_dec(Item *arg, Item *item) const;

  /* Hybrid_type operations. */
  virtual void set_zero(Hybrid_type *val) const
  { val->integer= 0; }
  virtual void add(Hybrid_type *val, Field *f) const
  { val->integer+= f->val_int(); }
  virtual void div(Hybrid_type *val, ulonglong u) const
  { val->integer/= (longlong) u; }

  virtual longlong val_int(Hybrid_type *val, bool unsigned_flag) const
  { return val->integer; }
  virtual double val_real(Hybrid_type *val) const
  { return (double) val->integer; }
  virtual my_decimal *val_decimal(Hybrid_type *val, my_decimal *buf) const
  {
    int2my_decimal(E_DEC_FATAL_ERROR, val->integer, 0, &val->dec_buf[2]);
    return &val->dec_buf[2];
  }
  virtual String *val_str(Hybrid_type *val, String *buf, uint8 decimals) const
  { buf->set(val->integer, &my_charset_bin); return buf;}
  static const Hybrid_type_traits_integer *instance();
256
  Hybrid_type_traits_integer() {};
257 258
};

259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278

void dummy_error_processor(THD *thd, void *data);

void view_error_processor(THD *thd, void *data);

/*
  Instances of Name_resolution_context store the information necesary for
  name resolution of Items and other context analysis of a query made in
  fix_fields().

  This structure is a part of SELECT_LEX, a pointer to this structure is
  assigned when an item is created (which happens mostly during  parsing
  (sql_yacc.yy)), but the structure itself will be initialized after parsing
  is complete

  TODO: move subquery of INSERT ... SELECT and CREATE ... SELECT to
  separate SELECT_LEX which allow to remove tricks of changing this
  structure before and after INSERT/CREATE and its SELECT to make correct
  field name resolution.
*/
279
struct Name_resolution_context: Sql_alloc
280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295
{
  /*
    The name resolution context to search in when an Item cannot be
    resolved in this context (the context of an outer select)
  */
  Name_resolution_context *outer_context;

  /*
    List of tables used to resolve the items of this context.  Usually these
    are tables from the FROM clause of SELECT statement.  The exceptions are
    INSERT ... SELECT and CREATE ... SELECT statements, where SELECT
    subquery is not moved to a separate SELECT_LEX.  For these types of
    statements we have to change this member dynamically to ensure correct
    name resolution of different parts of the statement.
  */
  TABLE_LIST *table_list;
unknown's avatar
unknown committed
296 297 298 299 300 301 302 303 304 305 306 307 308
  /*
    In most cases the two table references below replace 'table_list' above
    for the purpose of name resolution. The first and last name resolution
    table references allow us to search only in a sub-tree of the nested
    join tree in a FROM clause. This is needed for NATURAL JOIN, JOIN ... USING
    and JOIN ... ON. 
  */
  TABLE_LIST *first_name_resolution_table;
  /*
    Last table to search in the list of leaf table references that begins
    with first_name_resolution_table.
  */
  TABLE_LIST *last_name_resolution_table;
309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332

  /*
    SELECT_LEX item belong to, in case of merged VIEW it can differ from
    SELECT_LEX where item was created, so we can't use table_list/field_list
    from there
  */
  st_select_lex *select_lex;

  /*
    Processor of errors caused during Item name resolving, now used only to
    hide underlying tables in errors about views (i.e. it substitute some
    errors for views)
  */
  void (*error_processor)(THD *, void *);
  void *error_processor_data;

  /*
    When TRUE items are resolved in this context both against the
    SELECT list and this->table_list. If FALSE, items are resolved
    only against this->table_list.
  */
  bool resolve_in_select_list;

  /*
333 334
    Security context of this name resolution context. It's used for views
    and is non-zero only if the view is defined with SQL SECURITY DEFINER.
335
  */
336
  Security_context *security_ctx;
337 338 339 340

  Name_resolution_context()
    :outer_context(0), table_list(0), select_lex(0),
    error_processor_data(0),
341
    security_ctx(0)
342 343 344 345 346 347
    {}

  void init()
  {
    resolve_in_select_list= FALSE;
    error_processor= &dummy_error_processor;
unknown's avatar
unknown committed
348 349
    first_name_resolution_table= NULL;
    last_name_resolution_table= NULL;
350 351 352 353
  }

  void resolve_in_table_list_only(TABLE_LIST *tables)
  {
unknown's avatar
unknown committed
354
    table_list= first_name_resolution_table= tables;
355 356 357 358 359 360 361 362 363 364
    resolve_in_select_list= FALSE;
  }

  void process_error(THD *thd)
  {
    (*error_processor)(thd, error_processor_data);
  }
};


365 366 367 368 369 370 371 372 373 374 375
/*
  Store and restore the current state of a name resolution context.
*/

class Name_resolution_context_state
{
private:
  TABLE_LIST *save_table_list;
  TABLE_LIST *save_first_name_resolution_table;
  TABLE_LIST *save_next_name_resolution_table;
  bool        save_resolve_in_select_list;
376
  TABLE_LIST *save_next_local;
377 378

public:
379
  Name_resolution_context_state() {}          /* Remove gcc warning */
380 381 382 383 384 385 386 387 388

public:
  /* Save the state of a name resolution context. */
  void save_state(Name_resolution_context *context, TABLE_LIST *table_list)
  {
    save_table_list=                  context->table_list;
    save_first_name_resolution_table= context->first_name_resolution_table;
    save_resolve_in_select_list=      context->resolve_in_select_list;
    save_next_local=                  table_list->next_local;
389
    save_next_name_resolution_table=  table_list->next_name_resolution_table;
390 391 392 393 394 395
  }

  /* Restore a name resolution context from saved state. */
  void restore_state(Name_resolution_context *context, TABLE_LIST *table_list)
  {
    table_list->next_local=                save_next_local;
396
    table_list->next_name_resolution_table= save_next_name_resolution_table;
397 398 399 400
    context->table_list=                   save_table_list;
    context->first_name_resolution_table=  save_first_name_resolution_table;
    context->resolve_in_select_list=       save_resolve_in_select_list;
  }
401 402 403 404 405

  TABLE_LIST *get_first_name_resolution_table()
  {
    return save_first_name_resolution_table;
  }
406 407
};

unknown's avatar
unknown committed
408 409 410 411 412 413 414 415 416 417 418 419 420

/*
  This enum is used to report information about monotonicity of function
  represented by Item* tree.
  Monotonicity is defined only for Item* trees that represent table
  partitioning expressions (i.e. have no subselects/user vars/PS parameters
  etc etc). An Item* tree is assumed to have the same monotonicity properties
  as its correspoinding function F:

  [signed] longlong F(field1, field2, ...) {
    put values of field_i into table record buffer;
    return item->val_int(); 
  }
421 422 423 424 425 426 427

  NOTE
  At the moment function monotonicity is not well defined (and so may be
  incorrect) for Item trees with parameters/return types that are different
  from INT_RESULT, may be NULL, or are unsigned.
  It will be possible to address this issue once the related partitioning bugs
  (BUG#16002, BUG#15447, BUG#13436) are fixed.
428 429 430 431 432

  The NOT_NULL enums are used in TO_DAYS, since TO_DAYS('2001-00-00') returns
  NULL which puts those rows into the NULL partition, but
  '2000-12-31' < '2001-00-00' < '2001-01-01'. So special handling is needed
  for this (see Bug#20577).
unknown's avatar
unknown committed
433 434 435 436 437
*/

typedef enum monotonicity_info 
{
   NON_MONOTONIC,              /* none of the below holds */
438
   MONOTONIC_INCREASING,       /* F() is unary and (x < y) => (F(x) <= F(y)) */
439 440 441
   MONOTONIC_INCREASING_NOT_NULL,  /* But only for valid/real x and y */
   MONOTONIC_STRICT_INCREASING,/* F() is unary and (x < y) => (F(x) <  F(y)) */
   MONOTONIC_STRICT_INCREASING_NOT_NULL  /* But only for valid/real x and y */
unknown's avatar
unknown committed
442 443
} enum_monotonicity_info;

444 445
/*************************************************************************/

446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461
class sp_rcontext;


class Settable_routine_parameter
{
public:
  /*
    Set required privileges for accessing the parameter.

    SYNOPSIS
      set_required_privilege()
        rw        if 'rw' is true then we are going to read and set the
                  parameter, so SELECT and UPDATE privileges might be
                  required, otherwise we only reading it and SELECT
                  privilege might be required.
  */
462 463
  Settable_routine_parameter() {}
  virtual ~Settable_routine_parameter() {}
464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479
  virtual void set_required_privilege(bool rw) {};

  /*
    Set parameter value.

    SYNOPSIS
      set_value()
        thd       thread handle
        ctx       context to which parameter belongs (if it is local
                  variable).
        it        item which represents new value

    RETURN
      FALSE if parameter value has been set,
      TRUE if error has occured.
  */
480
  virtual bool set_value(THD *thd, sp_rcontext *ctx, Item **it)= 0;
481 482 483 484 485

  virtual void set_out_param_info(Send_field *info) {}

  virtual const Send_field *get_out_param_info() const
  { return NULL; }
486 487 488
};


489
typedef bool (Item::*Item_processor) (uchar *arg);
490 491 492 493 494 495 496 497 498 499 500
/*
  Analyzer function
    SYNOPSIS
      argp   in/out IN:  Analysis parameter
                    OUT: Parameter to be passed to the transformer

    RETURN 
      TRUE   Invoke the transformer
      FALSE  Don't do it

*/
501 502
typedef bool (Item::*Item_analyzer) (uchar **argp);
typedef Item* (Item::*Item_transformer) (uchar *arg);
503
typedef void (*Cond_traverser) (const Item *item, void *arg);
504

505

unknown's avatar
unknown committed
506
class Item {
unknown's avatar
unknown committed
507
  Item(const Item &);			/* Prevent use of these */
unknown's avatar
unknown committed
508 509
  void operator=(Item &);
public:
510
  static void *operator new(size_t size) throw ()
511
  { return sql_alloc(size); }
512
  static void *operator new(size_t size, MEM_ROOT *mem_root) throw ()
513
  { return alloc_root(mem_root, size); }
unknown's avatar
unknown committed
514
  static void operator delete(void *ptr,size_t size) { TRASH(ptr, size); }
515
  static void operator delete(void *ptr, MEM_ROOT *mem_root) {}
unknown's avatar
unknown committed
516

517
  enum Type {FIELD_ITEM= 0, FUNC_ITEM, SUM_FUNC_ITEM, STRING_ITEM,
518
	     INT_ITEM, REAL_ITEM, NULL_ITEM, VARBIN_ITEM,
unknown's avatar
SCRUM  
unknown committed
519
	     COPY_STR_ITEM, FIELD_AVG_ITEM, DEFAULT_VALUE_ITEM,
unknown's avatar
unknown committed
520 521
	     PROC_ITEM,COND_ITEM, REF_ITEM, FIELD_STD_ITEM,
	     FIELD_VARIANCE_ITEM, INSERT_VALUE_ITEM,
522
             SUBSELECT_ITEM, ROW_ITEM, CACHE_ITEM, TYPE_HOLDER,
523
             PARAM_ITEM, TRIGGER_FIELD_ITEM, DECIMAL_ITEM,
524
             XPATH_NODESET, XPATH_NODESET_CMP,
525
             VIEW_FIXER_ITEM};
unknown's avatar
SCRUM  
unknown committed
526

unknown's avatar
unknown committed
527
  enum cond_result { COND_UNDEF,COND_OK,COND_TRUE,COND_FALSE };
528 529

  enum traverse_order { POSTFIX, PREFIX };
530
  
531 532 533
  /* Reuse size, only used by SP local variable assignment, otherwize 0 */
  uint rsize;

unknown's avatar
unknown committed
534 535 536 537 538
  /*
    str_values's main purpose is to be used to cache the value in
    save_in_field
  */
  String str_value;
539
  char * name;			/* Name from select */
540
  /* Original item name (if it was renamed)*/
541
  char * orig_name;
542 543 544 545 546 547 548
  /**
     Intrusive list pointer for free list. If not null, points to the next
     Item on some Query_arena's free list. For instance, stored procedures
     have their own Query_arena's.

     @see Query_arena::free_list
   */
unknown's avatar
unknown committed
549
  Item *next;
550
  uint32 max_length;                    /* Maximum length, in bytes */
551
  uint name_length;                     /* Length of name */
552 553
  int8 marker;
  uint8 decimals;
unknown's avatar
unknown committed
554 555
  my_bool maybe_null;			/* If item may be null */
  my_bool null_value;			/* if item is null */
556
  my_bool unsigned_flag;
unknown's avatar
unknown committed
557
  my_bool with_sum_func;
558
  my_bool fixed;                        /* If item fixed with fix_fields */
559 560
  my_bool is_autogenerated_name;        /* indicate was name of this Item
                                           autogenerated or set by user */
561
  DTCollation collation;
562 563 564
  my_bool with_subselect;               /* If this item is a subselect or some
                                           of its arguments is or contains a
                                           subselect */
565
  Item_result cmp_context;              /* Comparison context */
unknown's avatar
unknown committed
566 567
  // alloc & destruct is done as start of select using sql_alloc
  Item();
568
  /*
unknown's avatar
unknown committed
569
     Constructor used by Item_field, Item_ref & aggregate (sum) functions.
570 571
     Used for duplicating lists in processing queries with temporary
     tables
572
     Also it used for Item_cond_and/Item_cond_or for creating
unknown's avatar
unknown committed
573
     top AND/OR structure of WHERE clause to protect it of
574
     optimisation changes in prepared statements
575
  */
576
  Item(THD *thd, Item *item);
unknown's avatar
unknown committed
577 578
  virtual ~Item()
  {
unknown's avatar
unknown committed
579
#ifdef EXTRA_DEBUG
unknown's avatar
unknown committed
580
    name=0;
unknown's avatar
unknown committed
581
#endif
unknown's avatar
unknown committed
582
  }		/*lint -e1509 */
583
  void set_name(const char *str, uint length, CHARSET_INFO *cs);
584
  void rename(char *new_name);
unknown's avatar
unknown committed
585
  void init_make_field(Send_field *tmp_field,enum enum_field_types type);
586
  virtual void cleanup();
587
  virtual void make_field(Send_field *field);
588
  Field *make_string_field(TABLE *table);
589
  virtual bool fix_fields(THD *, Item **);
unknown's avatar
unknown committed
590
  /*
unknown's avatar
unknown committed
591
    should be used in case where we are sure that we do not need
unknown's avatar
unknown committed
592 593 594
    complete fix_fields() procedure.
  */
  inline void quick_fix_field() { fixed= 1; }
unknown's avatar
unknown committed
595
  /* Function returns 1 on overflow and -1 on fatal errors */
596
  int save_in_field_no_warnings(Field *field, bool no_conversions);
unknown's avatar
unknown committed
597
  virtual int save_in_field(Field *field, bool no_conversions);
unknown's avatar
unknown committed
598
  virtual void save_org_in_field(Field *field)
599
  { (void) save_in_field(field, 1); }
unknown's avatar
unknown committed
600
  virtual int save_safe_in_field(Field *field)
601
  { return save_in_field(field, 1); }
602
  virtual bool send(Protocol *protocol, String *str);
603
  virtual bool eq(const Item *, bool binary_cmp) const;
604 605
  virtual Item_result result_type() const { return REAL_RESULT; }
  virtual Item_result cast_to_int_type() const { return result_type(); }
606
  virtual enum_field_types string_field_type() const;
607
  virtual enum_field_types field_type() const;
unknown's avatar
unknown committed
608
  virtual enum Type type() const =0;
unknown's avatar
unknown committed
609 610 611 612 613 614 615 616 617
  
  /*
    Return information about function monotonicity. See comment for
    enum_monotonicity_info for details. This function can only be called
    after fix_fields() call.
  */
  virtual enum_monotonicity_info get_monotonicity_info() const
  { return NON_MONOTONIC; }

618 619 620 621 622 623 624 625
  /*
    Convert "func_arg $CMP$ const" half-interval into "FUNC(func_arg) $CMP2$ const2"

    SYNOPSIS
      val_int_endpoint()
        left_endp  FALSE  <=> The interval is "x < const" or "x <= const"
                   TRUE   <=> The interval is "x > const" or "x >= const"

626 627
        incl_endp  IN   FALSE <=> the comparison is '<' or '>'
                        TRUE  <=> the comparison is '<=' or '>='
628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651
                   OUT  The same but for the "F(x) $CMP$ F(const)" comparison

    DESCRIPTION
      This function is defined only for unary monotonic functions. The caller
      supplies the source half-interval

         x $CMP$ const

      The value of const is supplied implicitly as the value this item's
      argument, the form of $CMP$ comparison is specified through the
      function's arguments. The calle returns the result interval
         
         F(x) $CMP2$ F(const)
      
      passing back F(const) as the return value, and the form of $CMP2$ 
      through the out parameter. NULL values are assumed to be comparable and
      be less than any non-NULL values.

    RETURN
      The output range bound, which equal to the value of val_int()
        - If the value of the function is NULL then the bound is the 
          smallest possible value of LONGLONG_MIN 
  */
  virtual longlong val_int_endpoint(bool left_endp, bool *incl_endp)
unknown's avatar
unknown committed
652
  { DBUG_ASSERT(0); return 0; }
653 654


655
  /* valXXX methods must return NULL or 0 or 0.0 if null_value is set. */
unknown's avatar
unknown committed
656 657 658 659 660 661 662 663 664 665
  /*
    Return double precision floating point representation of item.

    SYNOPSIS
      val_real()

    RETURN
      In case of NULL value return 0.0 and set null_value flag to TRUE.
      If value is not null null_value flag will be reset to FALSE.
  */
666
  virtual double val_real()=0;
unknown's avatar
unknown committed
667 668 669 670 671 672 673 674 675 676
  /*
    Return integer representation of item.

    SYNOPSIS
      val_int()

    RETURN
      In case of NULL value return 0 and set null_value flag to TRUE.
      If value is not null null_value flag will be reset to FALSE.
  */
unknown's avatar
unknown committed
677
  virtual longlong val_int()=0;
678 679 680 681 682
  /*
    This is just a shortcut to avoid the cast. You should still use
    unsigned_flag to check the sign of the item.
  */
  inline ulonglong val_uint() { return (ulonglong) val_int(); }
683 684 685
  /*
    Return string representation of this item object.

unknown's avatar
unknown committed
686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717
    SYNOPSIS
      val_str()
      str   an allocated buffer this or any nested Item object can use to
            store return value of this method.

    NOTE
      Buffer passed via argument  should only be used if the item itself
      doesn't have an own String buffer. In case when the item maintains
      it's own string buffer, it's preferable to return it instead to
      minimize number of mallocs/memcpys.
      The caller of this method can modify returned string, but only in case
      when it was allocated on heap, (is_alloced() is true).  This allows
      the caller to efficiently use a buffer allocated by a child without
      having to allocate a buffer of it's own. The buffer, given to
      val_str() as argument, belongs to the caller and is later used by the
      caller at it's own choosing.
      A few implications from the above:
      - unless you return a string object which only points to your buffer
        but doesn't manages it you should be ready that it will be
        modified.
      - even for not allocated strings (is_alloced() == false) the caller
        can change charset (see Item_func_{typecast/binary}. XXX: is this
        a bug?
      - still you should try to minimize data copying and return internal
        object whenever possible.

    RETURN
      In case of NULL value return 0 (NULL pointer) and set null_value flag
      to TRUE.
      If value is not null null_value flag will be reset to FALSE.
  */
  virtual String *val_str(String *str)=0;
718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788

  /*
    Returns string representation of this item in ASCII format.

    SYNOPSIS
      val_str_ascii()
      str - similar to val_str();

    NOTE
      This method is introduced for performance optimization purposes.

      1. val_str() result of some Items in string context
      depends on @@character_set_results.
      @@character_set_results can be set to a "real multibyte" character
      set like UCS2, UTF16, UTF32. (We'll use only UTF32 in the examples
      below for convenience.)

      So the default string result of such functions
      in these circumstances is real multi-byte character set, like UTF32.

      For example, all numbers in string context
      return result in @@character_set_results:

      SELECT CONCAT(20010101); -> UTF32

      We do sprintf() first (to get ASCII representation)
      and then convert to UTF32;
      
      So these kind "data sources" can use ASCII representation
      internally, but return multi-byte data only because
      @@character_set_results wants so.
      Therefore, conversion from ASCII to UTF32 is applied internally.


      2. Some other functions need in fact ASCII input.

      For example,
        inet_aton(), GeometryFromText(), Convert_TZ(), GET_FORMAT().

      Similar, fields of certain type, like DATE, TIME,
      when you insert string data into them, expect in fact ASCII input.
      If they get non-ASCII input, for example UTF32, they
      convert input from UTF32 to ASCII, and then use ASCII
      representation to do further processing.


      3. Now imagine we pass result of a data source of the first type
         to a data destination of the second type.

      What happens:
        a. data source converts data from ASCII to UTF32, because
           @@character_set_results wants so and passes the result to
           data destination.
        b. data destination gets UTF32 string.
        c. data destination converts UTF32 string to ASCII,
           because it needs ASCII representation to be able to handle data
           correctly.

      As a result we get two steps of unnecessary conversion:
      From ASCII to UTF32, then from UTF32 to ASCII.

      A better way to handle these situations is to pass ASCII
      representation directly from the source to the destination.

      This is why val_str_ascii() introduced.

    RETURN
      Similar to val_str()
  */
  virtual String *val_str_ascii(String *str);
  
unknown's avatar
unknown committed
789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813
  /*
    Return decimal representation of item with fixed point.

    SYNOPSIS
      val_decimal()
      decimal_buffer  buffer which can be used by Item for returning value
                      (but can be not)

    NOTE
      Returned value should not be changed if it is not the same which was
      passed via argument.

    RETURN
      Return pointer on my_decimal (it can be other then passed via argument)
        if value is not NULL (null_value flag will be reset to FALSE).
      In case of NULL value it return 0 pointer and set null_value flag
        to TRUE.
  */
  virtual my_decimal *val_decimal(my_decimal *decimal_buffer)= 0;
  /*
    Return boolean value of item.

    RETURN
      FALSE value is false or NULL
      TRUE value is true (not equal to 0)
814
  */
unknown's avatar
unknown committed
815
  virtual bool val_bool();
816
  virtual String *val_nodeset(String*) { return 0; }
817 818 819 820 821 822 823
  /* Helper functions, see item_sum.cc */
  String *val_string_from_real(String *str);
  String *val_string_from_int(String *str);
  String *val_string_from_decimal(String *str);
  my_decimal *val_decimal_from_real(my_decimal *decimal_value);
  my_decimal *val_decimal_from_int(my_decimal *decimal_value);
  my_decimal *val_decimal_from_string(my_decimal *decimal_value);
824 825
  my_decimal *val_decimal_from_date(my_decimal *decimal_value);
  my_decimal *val_decimal_from_time(my_decimal *decimal_value);
826 827 828
  longlong val_int_from_decimal();
  double val_real_from_decimal();

829 830
  int save_time_in_field(Field *field);
  int save_date_in_field(Field *field);
831
  int save_str_value_in_field(Field *field, String *result);
832

833
  virtual Field *get_tmp_table_field() { return 0; }
unknown's avatar
unknown committed
834
  /* This is also used to create fields in CREATE ... SELECT: */
835
  virtual Field *tmp_table_field(TABLE *t_arg) { return 0; }
unknown's avatar
unknown committed
836
  virtual const char *full_name() const { return name ? name : "???"; }
unknown's avatar
unknown committed
837 838 839 840 841 842 843

  /*
    *result* family of methods is analog of *val* family (see above) but
    return value of result_field of item if it is present. If Item have not
    result field, it return val(). This methods set null_value flag in same
    way as *val* methods do it.
  */
844
  virtual double  val_result() { return val_real(); }
unknown's avatar
unknown committed
845 846
  virtual longlong val_int_result() { return val_int(); }
  virtual String *str_result(String* tmp) { return val_str(tmp); }
unknown's avatar
unknown committed
847 848 849
  virtual my_decimal *val_decimal_result(my_decimal *val)
  { return val_decimal(val); }
  virtual bool val_bool_result() { return val_bool(); }
850
  virtual bool is_null_result() { return is_null(); }
unknown's avatar
unknown committed
851

852
  /* bit map of tables used by item */
unknown's avatar
unknown committed
853
  virtual table_map used_tables() const { return (table_map) 0L; }
854 855 856 857 858 859 860 861 862 863 864 865 866 867
  /*
    Return table map of tables that can't be NULL tables (tables that are
    used in a context where if they would contain a NULL row generated
    by a LEFT or RIGHT join, the item would not be true).
    This expression is used on WHERE item to determinate if a LEFT JOIN can be
    converted to a normal join.
    Generally this function should return used_tables() if the function
    would return null if any of the arguments are null
    As this is only used in the beginning of optimization, the value don't
    have to be updated in update_used_tables()
  */
  virtual table_map not_null_tables() const { return used_tables(); }
  /*
    Returns true if this is a simple constant item like an integer, not
868
    a constant expression. Used in the optimizer to propagate basic constants.
869
  */
unknown's avatar
unknown committed
870
  virtual bool basic_const_item() const { return 0; }
unknown's avatar
unknown committed
871
  /* cloning of constant items (0 if it is not const) */
872
  virtual Item *clone_item() { return 0; }
unknown's avatar
unknown committed
873 874 875
  virtual cond_result eq_cmp_result() const { return COND_OK; }
  inline uint float_length(uint decimals_par) const
  { return decimals != NOT_FIXED_DEC ? (DBL_DIG+2+decimals_par) : DBL_DIG+8;}
unknown's avatar
unknown committed
876 877
  virtual uint decimal_precision() const;
  inline int decimal_int_part() const
878
  { return my_decimal_int_part(decimal_precision(), decimals); }
879 880 881 882
  /* 
    Returns true if this is constant (during query execution, i.e. its value
    will not change until next fix_fields) and its value is known.
  */
unknown's avatar
unknown committed
883
  virtual bool const_item() const { return used_tables() == 0; }
884 885 886 887 888 889
  /* 
    Returns true if this is constant but its value may be not known yet.
    (Can be used for parameters of prep. stmts or of stored procedures.)
  */
  virtual bool const_during_execution() const 
  { return (used_tables() & ~PARAM_TABLE_BIT) == 0; }
890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907

  /**
    This method is used for to:
      - to generate a view definition query (SELECT-statement);
      - to generate a SQL-query for EXPLAIN EXTENDED;
      - to generate a SQL-query to be shown in INFORMATION_SCHEMA;
      - debug.

    For more information about view definition query, INFORMATION_SCHEMA
    query and why they should be generated from the Item-tree, @see
    mysql_register_view().
  */
  virtual inline void print(String *str, enum_query_type query_type)
  {
    str->append(full_name());
  }

  void print_item_w_name(String *, enum_query_type query_type);
unknown's avatar
unknown committed
908
  virtual void update_used_tables() {}
909 910
  virtual void split_sum_func(THD *thd, Item **ref_pointer_array,
                              List<Item> &fields) {}
911 912
  /* Called for items that really have to be split */
  void split_sum_func2(THD *thd, Item **ref_pointer_array, List<Item> &fields,
unknown's avatar
unknown committed
913
                       Item **ref, bool skip_registered);
914 915 916
  virtual bool get_date(MYSQL_TIME *ltime,uint fuzzydate);
  virtual bool get_time(MYSQL_TIME *ltime);
  virtual bool get_date_result(MYSQL_TIME *ltime,uint fuzzydate)
917
  { return get_date(ltime,fuzzydate); }
918
  /*
919 920 921 922 923
    The method allows to determine nullness of a complex expression 
    without fully evaluating it, instead of calling val/result*() then 
    checking null_value. Used in Item_func_isnull/Item_func_isnotnull
    and Item_sum_count/Item_sum_count_distinct.
    Any new item which can be NULL must implement this method.
924
  */
925
  virtual bool is_null() { return 0; }
926

927 928 929 930 931
  /*
   Make sure the null_value member has a correct value.
  */
  virtual void update_null_value () { (void) val_int(); }

unknown's avatar
unknown committed
932
  /*
933 934 935 936 937 938 939 940
    Inform the item that there will be no distinction between its result
    being FALSE or NULL.

    NOTE
      This function will be called for eg. Items that are top-level AND-parts
      of the WHERE clause. Items implementing this function (currently
      Item_cond_and and subquery-related item) enable special optimizations
      when they are "top level".
unknown's avatar
unknown committed
941
  */
942
  virtual void top_level_item() {}
unknown's avatar
unknown committed
943 944
  /*
    set field of temporary table for Item which can be switched on temporary
unknown's avatar
unknown committed
945
    table during query processing (grouping and so on)
unknown's avatar
unknown committed
946
  */
unknown's avatar
unknown committed
947 948
  virtual void set_result_field(Field *field) {}
  virtual bool is_result_field() { return 0; }
unknown's avatar
unknown committed
949
  virtual bool is_bool_func() { return 0; }
unknown's avatar
unknown committed
950
  virtual void save_in_result_field(bool no_conversions) {}
unknown's avatar
unknown committed
951
  /*
unknown's avatar
unknown committed
952
    set value of aggregate function in case of no rows for grouping were found
unknown's avatar
unknown committed
953
  */
unknown's avatar
unknown committed
954
  virtual void no_rows_in_result() {}
955
  virtual Item *copy_or_same(THD *thd) { return this; }
956
  virtual Item *copy_andor_structure(THD *thd) { return this; }
unknown's avatar
unknown committed
957
  virtual Item *real_item() { return this; }
958
  virtual Item *get_tmp_table_item(THD *thd) { return copy_or_same(thd); }
unknown's avatar
unknown committed
959

960
  static CHARSET_INFO *default_charset();
961
  virtual CHARSET_INFO *compare_collation() { return NULL; }
unknown's avatar
unknown committed
962

963 964 965 966 967 968 969 970 971 972
  /*
    For backward compatibility, to make numeric
    data types return "binary" charset in client-side metadata.
  */
  virtual CHARSET_INFO *charset_for_protocol(void) const
  {
    return result_type() == STRING_RESULT ? collation.collation :
                                            &my_charset_bin;
  };

973
  virtual bool walk(Item_processor processor, bool walk_subquery, uchar *arg)
unknown's avatar
unknown committed
974 975 976 977
  {
    return (this->*processor)(arg);
  }

978
  virtual Item* transform(Item_transformer transformer, uchar *arg);
979

980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995
  /*
    This function performs a generic "compilation" of the Item tree.
    The process of compilation is assumed to go as follows: 
    
    compile()
    { 
      if (this->*some_analyzer(...))
      {
        compile children if any;
        this->*some_transformer(...);
      }
    }

    i.e. analysis is performed top-down while transformation is done
    bottom-up.      
  */
996 997
  virtual Item* compile(Item_analyzer analyzer, uchar **arg_p,
                        Item_transformer transformer, uchar *arg_t)
998 999 1000 1001 1002 1003
  {
    if ((this->*analyzer) (arg_p))
      return ((this->*transformer) (arg_t));
    return 0;
  }

1004 1005
   virtual void traverse_cond(Cond_traverser traverser,
                              void *arg, traverse_order order)
1006 1007 1008
   {
     (*traverser)(this, arg);
   }
1009

1010 1011 1012 1013 1014 1015 1016 1017 1018
  /*
    This is used to get the most recent version of any function in
    an item tree. The version is the version where a MySQL function
    was introduced in. So any function which is added should use
    this function and set the int_arg to maximum of the input data
    and their own version info.
  */
  virtual bool intro_version(uchar *int_arg) { return 0; }

1019 1020 1021 1022 1023 1024 1025 1026
  virtual bool remove_dependence_processor(uchar * arg) { return 0; }
  virtual bool remove_fixed(uchar * arg) { fixed= 0; return 0; }
  virtual bool cleanup_processor(uchar *arg);
  virtual bool collect_item_field_processor(uchar * arg) { return 0; }
  virtual bool find_item_in_field_list_processor(uchar *arg) { return 0; }
  virtual bool change_context_processor(uchar *context) { return 0; }
  virtual bool reset_query_id_processor(uchar *query_id_arg) { return 0; }
  virtual bool is_expensive_processor(uchar *arg) { return 0; }
1027
  virtual bool find_item_processor(uchar *arg) { return this == (void *) arg; }
1028
  virtual bool register_field_in_read_map(uchar *arg) { return 0; }
1029 1030 1031

  virtual bool cache_const_expr_analyzer(uchar **arg);
  virtual Item* cache_const_expr_transformer(uchar *arg);
1032
  /*
1033 1034 1035
    Check if a partition function is allowed
    SYNOPSIS
      check_partition_func_processor()
1036
      int_arg                        Ignored
1037
    RETURN VALUE
1038 1039 1040
      TRUE                           Partition function not accepted
      FALSE                          Partition function accepted

1041
    DESCRIPTION
1042
    check_partition_func_processor is used to check if a partition function
1043 1044 1045 1046 1047 1048 1049
    uses an allowed function. An allowed function will always ensure that
    X=Y guarantees that also part_function(X)=part_function(Y) where X is
    a set of partition fields and so is Y. The problems comes mainly from
    character sets where two equal strings can be quite unequal. E.g. the
    german character for double s is equal to 2 s.

    The default is that an item is not allowed
unknown's avatar
unknown committed
1050
    in a partition function. Allowed functions
1051 1052 1053 1054 1055 1056 1057 1058
    can never depend on server version, they cannot depend on anything
    related to the environment. They can also only depend on a set of
    fields in the table itself. They cannot depend on other tables and
    cannot contain any queries and cannot contain udf's or similar.
    If a new Item class is defined and it inherits from a class that is
    allowed in a partition function then it is very important to consider
    whether this should be inherited to the new class. If not the function
    below should be defined in the new Item class.
unknown's avatar
unknown committed
1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081

    The general behaviour is that most integer functions are allowed.
    If the partition function contains any multi-byte collations then
    the function check_part_func_fields will report an error on the
    partition function independent of what functions are used. So the
    only character sets allowed are single character collation and
    even for those only a limited set of functions are allowed. The
    problem with multi-byte collations is that almost every string
    function has the ability to change things such that two strings
    that are equal will not be equal after manipulated by a string
    function. E.g. two strings one contains a double s, there is a
    special german character that is equal to two s. Now assume a
    string function removes one character at this place, then in
    one the double s will be removed and in the other there will
    still be one s remaining and the strings are no longer equal
    and thus the partition function will not sort equal strings into
    the same partitions.

    So the check if a partition function is valid is two steps. First
    check that the field types are valid, next check that the partition
    function is valid. The current set of partition functions valid
    assumes that there are no multi-byte collations amongst the partition
    fields.
1082
  */
1083 1084
  virtual bool check_partition_func_processor(uchar *bool_arg) { return TRUE;}
  virtual bool subst_argument_checker(uchar **arg)
1085 1086 1087 1088 1089
  { 
    if (*arg)
      *arg= NULL; 
    return TRUE;     
  }
1090

1091 1092 1093
  virtual Item *equal_fields_propagator(uchar * arg) { return this; }
  virtual bool set_no_const_sub(uchar *arg) { return FALSE; }
  virtual Item *replace_equal_field(uchar * arg) { return this; }
1094 1095 1096 1097 1098 1099 1100 1101 1102
  /*
    Check if an expression value depends on the current timezone. Used by
    partitioning code to reject timezone-dependent expressions in a
    (sub)partitioning function.
  */
  virtual bool is_timezone_dependent_processor(uchar *bool_arg)
  {
    return FALSE;
  }
1103

1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120
  /**
    Find a function of a given type

    @param   arg     the function type to search (enum Item_func::Functype)
    @return
      @retval TRUE   the function type we're searching for is found
      @retval FALSE  the function type wasn't found

    @description
      This function can be used (together with Item::walk()) to find functions
      in an item tree fragment.
  */
  virtual bool find_function_processor (uchar *arg)
  {
    return FALSE;
  }

1121 1122 1123 1124 1125
  /*
    For SP local variable returns pointer to Item representing its
    current value and pointer to current Item otherwise.
  */
  virtual Item *this_item() { return this; }
1126 1127
  virtual const Item *this_item() const { return this; }

1128 1129 1130 1131
  /*
    For SP local variable returns address of pointer to Item representing its
    current value and pointer passed via parameter otherwise.
  */
1132
  virtual Item **this_item_addr(THD *thd, Item **addr_arg) { return addr_arg; }
unknown's avatar
unknown committed
1133 1134 1135

  // Row emulation
  virtual uint cols() { return 1; }
1136
  virtual Item* element_index(uint i) { return this; }
1137
  virtual Item** addr(uint i) { return 0; }
unknown's avatar
unknown committed
1138
  virtual bool check_cols(uint c);
unknown's avatar
unknown committed
1139
  // It is not row => null inside is impossible
1140 1141 1142
  virtual bool null_inside() { return 0; }
  // used in row subselects to get value of elements
  virtual void bring_value() {}
1143

unknown's avatar
unknown committed
1144
  Field *tmp_table_field_from_field_type(TABLE *table, bool fixed_length);
1145
  virtual Item_field *filed_for_view_update() { return 0; }
unknown's avatar
unknown committed
1146

1147
  virtual Item *neg_transformer(THD *thd) { return NULL; }
1148
  virtual Item *update_value_transformer(uchar *select_arg) { return this; }
unknown's avatar
unknown committed
1149
  virtual Item *safe_charset_converter(CHARSET_INFO *tocs);
1150 1151 1152 1153
  void delete_self()
  {
    cleanup();
    delete this;
unknown's avatar
unknown committed
1154
  }
1155 1156

  virtual bool is_splocal() { return 0; } /* Needed for error checking */
1157 1158 1159 1160 1161 1162 1163 1164 1165

  /*
    Return Settable_routine_parameter interface of the Item.  Return 0
    if this Item is not Settable_routine_parameter.
  */
  virtual Settable_routine_parameter *get_settable_routine_parameter()
  {
    return 0;
  }
1166 1167 1168 1169 1170 1171 1172 1173
  /*
    result_as_longlong() must return TRUE for Items representing DATE/TIME
    functions and DATE/TIME table fields.
    Those Items have result_type()==STRING_RESULT (and not INT_RESULT), but
    their values should be compared as integers (because the integer
    representation is more precise than the string one).
  */
  virtual bool result_as_longlong() { return FALSE; }
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
  inline bool is_datetime() const
  {
    switch (field_type())
    {
      case MYSQL_TYPE_DATE:
      case MYSQL_TYPE_DATETIME:
      case MYSQL_TYPE_TIMESTAMP:
        return TRUE;
      default:
        break;
    }
    return FALSE;
  }
  /**
    Check whether this and the given item has compatible comparison context.
    Used by the equality propagation. See Item_field::equal_fields_propagator.

    @return
      TRUE  if the context is the same or if fields could be
            compared as DATETIME values by the Arg_comparator.
      FALSE otherwise.
  */
  inline bool has_compatible_context(Item *item) const
  {
    /* Same context. */
    if (cmp_context == (Item_result)-1 || item->cmp_context == cmp_context)
      return TRUE;
    /* DATETIME comparison context. */
    if (is_datetime())
      return item->is_datetime() || item->cmp_context == STRING_RESULT;
    if (item->is_datetime())
      return is_datetime() || cmp_context == STRING_RESULT;
    return FALSE;
  }
1208 1209
  virtual Field::geometry_type get_geometry_type() const
    { return Field::GEOM_GEOMETRY; };
1210
  String *check_well_formed_result(String *str, bool send_error= 0);
unknown's avatar
unknown committed
1211
  bool eq_by_collation(Item *item, bool binary_cmp, CHARSET_INFO *cs); 
1212 1213 1214 1215
  uint32 max_char_length() const
  { return max_length / collation.collation->mbmaxlen; }
  void fix_length_and_charset(uint32 max_char_length_arg, CHARSET_INFO *cs)
  {
1216
    max_length= char_to_byte_length_safe(max_char_length_arg, cs->mbmaxlen);
1217 1218 1219
    collation.collation= cs;
  }
  void fix_char_length(uint32 max_char_length_arg)
1220 1221 1222 1223
  {
    max_length= char_to_byte_length_safe(max_char_length_arg,
                                         collation.collation->mbmaxlen);
  }
1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235
  void fix_char_length_ulonglong(ulonglong max_char_length_arg)
  {
    ulonglong max_result_length= max_char_length_arg *
                                 collation.collation->mbmaxlen;
    if (max_result_length >= MAX_BLOB_WIDTH)
    {
      max_length= MAX_BLOB_WIDTH;
      maybe_null= 1;
    }
    else
      max_length= max_result_length;
  }
1236 1237 1238 1239 1240
  void fix_length_and_charset_datetime(uint32 max_char_length_arg)
  {
    collation.set(&my_charset_numeric, DERIVATION_NUMERIC, MY_REPERTOIRE_ASCII);
    fix_char_length(max_char_length_arg);
  }
1241 1242 1243 1244
  /*
    Return TRUE if the item points to a column of an outer-joined table.
  */
  virtual bool is_outer_field() const { DBUG_ASSERT(fixed); return FALSE; }
unknown's avatar
unknown committed
1245 1246 1247
};


1248 1249
class sp_head;

1250

1251 1252
class Item_basic_constant :public Item
{
1253
  table_map used_table_map;
1254
public:
1255 1256 1257
  Item_basic_constant(): Item(), used_table_map(0) {};
  void set_used_tables(table_map map) { used_table_map= map; }
  table_map used_tables() const { return used_table_map; }
1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271
  /* to prevent drop fixed flag (no need parent cleanup call) */
  void cleanup()
  {
    /*
      Restore the original field name as it might not have been allocated
      in the statement memory. If the name is auto generated, it must be
      done again between subsequent executions of a prepared statement.
    */
    if (orig_name)
      name= orig_name;
  }
};


1272 1273 1274 1275 1276 1277 1278 1279
/*****************************************************************************
  The class is a base class for representation of stored routine variables in
  the Item-hierarchy. There are the following kinds of SP-vars:
    - local variables (Item_splocal);
    - CASE expression (Item_case_expr);
*****************************************************************************/

class Item_sp_variable :public Item
1280
{
1281 1282 1283 1284 1285 1286 1287 1288 1289 1290
protected:
  /*
    THD, which is stored in fix_fields() and is used in this_item() to avoid
    current_thd use.
  */
  THD *m_thd;

public:
  LEX_STRING m_name;

1291
public:
1292 1293 1294 1295 1296
#ifndef DBUG_OFF
  /*
    Routine to which this Item_splocal belongs. Used for checking if correct
    runtime context is used for variable handling.
  */
1297
  sp_head *m_sp;
1298
#endif
1299

1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331
public:
  Item_sp_variable(char *sp_var_name_str, uint sp_var_name_length);

public:
  bool fix_fields(THD *thd, Item **);

  double val_real();
  longlong val_int();
  String *val_str(String *sp);
  my_decimal *val_decimal(my_decimal *decimal_value);
  bool is_null();

public:
  inline void make_field(Send_field *field);
  
  inline bool const_item() const;
  
  inline int save_in_field(Field *field, bool no_conversions);
  inline bool send(Protocol *protocol, String *str);
}; 

/*****************************************************************************
  Item_sp_variable inline implementation.
*****************************************************************************/

inline void Item_sp_variable::make_field(Send_field *field)
{
  Item *it= this_item();

  if (name)
    it->set_name(name, (uint) strlen(name), system_charset_info);
  else
1332
    it->set_name(m_name.str, (uint) m_name.length, system_charset_info);
1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355 1356
  it->make_field(field);
}

inline bool Item_sp_variable::const_item() const
{
  return TRUE;
}

inline int Item_sp_variable::save_in_field(Field *field, bool no_conversions)
{
  return this_item()->save_in_field(field, no_conversions);
}

inline bool Item_sp_variable::send(Protocol *protocol, String *str)
{
  return this_item()->send(protocol, str);
}


/*****************************************************************************
  A reference to local SP variable (incl. reference to SP parameter), used in
  runtime.
*****************************************************************************/

1357 1358
class Item_splocal :public Item_sp_variable,
                    private Settable_routine_parameter
1359 1360 1361 1362 1363
{
  uint m_var_idx;

  Type m_type;
  Item_result m_result_type;
1364
  enum_field_types m_field_type;
1365
public:
1366 1367 1368 1369 1370 1371 1372
  /*
    Is this variable a parameter in LIMIT clause. 
    Used only during NAME_CONST substitution, to not append
    NAME_CONST to the resulting query and thus not break
    the slave.
  */
  bool limit_clause_param;
1373 1374 1375 1376 1377 1378 1379 1380 1381 1382
  /* 
    Position of this reference to SP variable in the statement (the
    statement itself is in sp_instr_stmt::m_query).
    This is valid only for references to SP variables in statements,
    excluding DECLARE CURSOR statement. It is used to replace references to SP
    variables with NAME_CONST calls when putting statements into the binary
    log.
    Value of 0 means that this object doesn't corresponding to reference to
    SP variable in query text.
  */
1383
  uint pos_in_query;
unknown's avatar
unknown committed
1384 1385 1386 1387 1388 1389 1390 1391
  /*
    Byte length of SP variable name in the statement (see pos_in_query).
    The value of this field may differ from the name_length value because
    name_length contains byte length of UTF8-encoded item name, but
    the query string (see sp_instr_stmt::m_query) is currently stored with
    a charset from the SET NAMES statement.
  */
  uint len_in_query;
1392

1393
  Item_splocal(const LEX_STRING &sp_var_name, uint sp_var_idx,
unknown's avatar
unknown committed
1394 1395
               enum_field_types sp_var_type,
               uint pos_in_q= 0, uint len_in_q= 0);
1396

1397 1398
  bool is_splocal() { return 1; } /* Needed for error checking */

1399
  Item *this_item();
1400
  const Item *this_item() const;
1401
  Item **this_item_addr(THD *thd, Item **);
1402

1403
  virtual void print(String *str, enum_query_type query_type);
unknown's avatar
unknown committed
1404

1405 1406
public:
  inline const LEX_STRING *my_name() const;
1407

1408
  inline uint get_var_idx() const;
1409

1410 1411
  inline enum Type type() const;
  inline Item_result result_type() const;
1412
  inline enum_field_types field_type() const { return m_field_type; }
1413 1414

private:
1415
  bool set_value(THD *thd, sp_rcontext *ctx, Item **it);
1416 1417 1418 1419 1420 1421

public:
  Settable_routine_parameter *get_settable_routine_parameter()
  {
    return this;
  }
1422
};
1423

1424 1425 1426
/*****************************************************************************
  Item_splocal inline implementation.
*****************************************************************************/
1427

1428 1429 1430 1431
inline const LEX_STRING *Item_splocal::my_name() const
{
  return &m_name;
}
1432

1433 1434 1435 1436
inline uint Item_splocal::get_var_idx() const
{
  return m_var_idx;
}
1437

1438 1439 1440 1441
inline enum Item::Type Item_splocal::type() const
{
  return m_type;
}
1442

1443 1444 1445 1446
inline Item_result Item_splocal::result_type() const
{
  return m_result_type;
}
unknown's avatar
unknown committed
1447

1448 1449 1450 1451 1452 1453 1454 1455

/*****************************************************************************
  A reference to case expression in SP, used in runtime.
*****************************************************************************/

class Item_case_expr :public Item_sp_variable
{
public:
1456
  Item_case_expr(uint case_expr_id);
1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471

public:
  Item *this_item();
  const Item *this_item() const;
  Item **this_item_addr(THD *thd, Item **);

  inline enum Type type() const;
  inline Item_result result_type() const;

public:
  /*
    NOTE: print() is intended to be used from views and for debug.
    Item_case_expr can not occur in views, so here it is only for debug
    purposes.
  */
1472
  virtual void print(String *str, enum_query_type query_type);
1473 1474

private:
1475
  uint m_case_expr_id;
1476 1477
};

1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491
/*****************************************************************************
  Item_case_expr inline implementation.
*****************************************************************************/

inline enum Item::Type Item_case_expr::type() const
{
  return this_item()->type();
}

inline Item_result Item_case_expr::result_type() const
{
  return this_item()->result_type();
}

1492

1493 1494 1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510
/*
  NAME_CONST(given_name, const_value). 
  This 'function' has all properties of the supplied const_value (which is 
  assumed to be a literal constant), and the name given_name. 

  This is used to replace references to SP variables when we write PROCEDURE
  statements into the binary log.

  TODO
    Together with Item_splocal and Item::this_item() we can actually extract
    common a base of this class and Item_splocal. Maybe it is possible to
    extract a common base with class Item_ref, too.
*/

class Item_name_const : public Item
{
  Item *value_item;
  Item *name_item;
1511
  bool valid_args;
1512
public:
1513
  Item_name_const(Item *name_arg, Item *val);
1514 1515 1516 1517 1518 1519 1520 1521 1522

  bool fix_fields(THD *, Item **);

  enum Type type() const;
  double val_real();
  longlong val_int();
  String *val_str(String *sp);
  my_decimal *val_decimal(my_decimal *);
  bool is_null();
1523
  virtual void print(String *str, enum_query_type query_type);
1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539

  Item_result result_type() const
  {
    return value_item->result_type();
  }

  bool const_item() const
  {
    return TRUE;
  }

  int save_in_field(Field *field, bool no_conversions)
  {
    return  value_item->save_in_field(field, no_conversions);
  }

1540
  bool send(Protocol *protocol, String *str)
1541 1542 1543 1544 1545
  {
    return value_item->send(protocol, str);
  }
};

1546
bool agg_item_collations(DTCollation &c, const char *name,
1547
                         Item **items, uint nitems, uint flags, int item_sep);
1548
bool agg_item_collations_for_comparison(DTCollation &c, const char *name,
1549
                                        Item **items, uint nitems, uint flags);
1550 1551
bool agg_item_set_converter(DTCollation &coll, const char *fname,
                            Item **args, uint nargs, uint flags, int item_sep);
1552
bool agg_item_charsets(DTCollation &c, const char *name,
1553
                       Item **items, uint nitems, uint flags, int item_sep);
1554 1555 1556 1557 1558 1559 1560 1561 1562 1563 1564 1565 1566 1567 1568 1569 1570 1571 1572
inline bool
agg_item_charsets_for_string_result(DTCollation &c, const char *name,
                                    Item **items, uint nitems,
                                    int item_sep= 1)
{
  uint flags= MY_COLL_ALLOW_SUPERSET_CONV |
              MY_COLL_ALLOW_COERCIBLE_CONV;
  return agg_item_charsets(c, name, items, nitems, flags, item_sep);
}
inline bool
agg_item_charsets_for_comparison(DTCollation &c, const char *name,
                                 Item **items, uint nitems,
                                 int item_sep= 1)
{
  uint flags= MY_COLL_ALLOW_SUPERSET_CONV |
              MY_COLL_ALLOW_COERCIBLE_CONV |
              MY_COLL_DISALLOW_NONE;
  return agg_item_charsets(c, name, items, nitems, flags, item_sep);
}
1573

1574
class Item_num: public Item_basic_constant
1575 1576
{
public:
1577
  Item_num() { collation.set_numeric(); } /* Remove gcc warning */
unknown's avatar
unknown committed
1578
  virtual Item_num *neg()= 0;
unknown's avatar
unknown committed
1579
  Item *safe_charset_converter(CHARSET_INFO *tocs);
1580
  bool check_partition_func_processor(uchar *int_arg) { return FALSE;}
1581 1582
};

1583
#define NO_CACHED_FIELD_INDEX ((uint)(-1))
1584

unknown's avatar
unknown committed
1585
class st_select_lex;
unknown's avatar
unknown committed
1586 1587
class Item_ident :public Item
{
1588
protected:
1589 1590 1591 1592 1593 1594 1595 1596 1597
  /* 
    We have to store initial values of db_name, table_name and field_name
    to be able to restore them during cleanup() because they can be 
    updated during fix_fields() to values from Field object and life-time 
    of those is shorter than life-time of Item_field.
  */
  const char *orig_db_name;
  const char *orig_table_name;
  const char *orig_field_name;
1598

unknown's avatar
unknown committed
1599
public:
1600
  Name_resolution_context *context;
unknown's avatar
unknown committed
1601 1602 1603
  const char *db_name;
  const char *table_name;
  const char *field_name;
unknown's avatar
unknown committed
1604
  bool alias_name_used; /* true if item was resolved against alias */
1605 1606
  /* 
    Cached value of index for this field in table->field array, used by prep. 
1607 1608 1609 1610 1611 1612 1613 1614
    stmts for speeding up their re-execution. Holds NO_CACHED_FIELD_INDEX 
    if index value is not known.
  */
  uint cached_field_index;
  /*
    Cached pointer to table which contains this field, used for the same reason
    by prep. stmt. too in case then we have not-fully qualified field.
    0 - means no cached value.
1615
  */
1616
  TABLE_LIST *cached_table;
unknown's avatar
unknown committed
1617
  st_select_lex *depended_from;
1618 1619 1620
  Item_ident(Name_resolution_context *context_arg,
             const char *db_name_arg, const char *table_name_arg,
             const char *field_name_arg);
unknown's avatar
unknown committed
1621
  Item_ident(THD *thd, Item_ident *item);
1622
  Item_ident(TABLE_LIST *view_arg, const char *field_name_arg);
unknown's avatar
unknown committed
1623
  const char *full_name() const;
1624
  void cleanup();
1625
  bool remove_dependence_processor(uchar * arg);
1626
  virtual void print(String *str, enum_query_type query_type);
1627
  virtual bool change_context_processor(uchar *cntx)
1628
    { context= (Name_resolution_context *)cntx; return FALSE; }
unknown's avatar
unknown committed
1629 1630 1631 1632
  friend bool insert_fields(THD *thd, Name_resolution_context *context,
                            const char *db_name,
                            const char *table_name, List_iterator<Item> *it,
                            bool any_privileges);
unknown's avatar
unknown committed
1633 1634
};

1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656

class Item_ident_for_show :public Item
{
public:
  Field *field;
  const char *db_name;
  const char *table_name;

  Item_ident_for_show(Field *par_field, const char *db_arg,
                      const char *table_name_arg)
    :field(par_field), db_name(db_arg), table_name(table_name_arg)
  {}

  enum Type type() const { return FIELD_ITEM; }
  double val_real() { return field->val_real(); }
  longlong val_int() { return field->val_int(); }
  String *val_str(String *str) { return field->val_str(str); }
  my_decimal *val_decimal(my_decimal *dec) { return field->val_decimal(dec); }
  void make_field(Send_field *tmp_field);
};


1657 1658
class Item_equal;
class COND_EQUAL;
unknown's avatar
unknown committed
1659

unknown's avatar
unknown committed
1660 1661
class Item_field :public Item_ident
{
1662
protected:
unknown's avatar
unknown committed
1663 1664 1665
  void set_field(Field *field);
public:
  Field *field,*result_field;
unknown's avatar
unknown committed
1666 1667
  Item_equal *item_equal;
  bool no_const_subst;
unknown's avatar
VIEW  
unknown committed
1668 1669 1670 1671 1672 1673 1674
  /*
    if any_privileges set to TRUE then here real effective privileges will
    be stored
  */
  uint have_privileges;
  /* field need any privileges (for VIEW creation) */
  bool any_privileges;
1675 1676 1677
  Item_field(Name_resolution_context *context_arg,
             const char *db_arg,const char *table_name_arg,
	     const char *field_name_arg);
1678 1679 1680
  /*
    Constructor needed to process subselect with temporary tables (see Item)
  */
1681
  Item_field(THD *thd, Item_field *item);
1682
  /*
1683 1684 1685
    Constructor used inside setup_wild(), ensures that field, table,
    and database names will live as long as Item_field (this is important
    in prepared statements).
1686
  */
1687
  Item_field(THD *thd, Name_resolution_context *context_arg, Field *field);
1688 1689 1690
  /*
    If this constructor is used, fix_fields() won't work, because
    db_name, table_name and column_name are unknown. It's necessary to call
1691
    reset_field() before fix_fields() for all fields created this way.
1692
  */
unknown's avatar
unknown committed
1693 1694
  Item_field(Field *field);
  enum Type type() const { return FIELD_ITEM; }
1695
  bool eq(const Item *item, bool binary_cmp) const;
1696
  double val_real();
unknown's avatar
unknown committed
1697
  longlong val_int();
unknown's avatar
unknown committed
1698
  my_decimal *val_decimal(my_decimal *);
unknown's avatar
unknown committed
1699 1700 1701 1702
  String *val_str(String*);
  double val_result();
  longlong val_int_result();
  String *str_result(String* tmp);
unknown's avatar
unknown committed
1703 1704
  my_decimal *val_decimal_result(my_decimal *);
  bool val_bool_result();
1705
  bool is_null_result();
1706
  bool send(Protocol *protocol, String *str_arg);
1707
  void reset_field(Field *f);
1708
  bool fix_fields(THD *, Item **);
1709
  void make_field(Send_field *tmp_field);
unknown's avatar
unknown committed
1710
  int save_in_field(Field *field,bool no_conversions);
unknown's avatar
unknown committed
1711 1712 1713 1714 1715 1716
  void save_org_in_field(Field *field);
  table_map used_tables() const;
  enum Item_result result_type () const
  {
    return field->result_type();
  }
1717 1718 1719 1720
  Item_result cast_to_int_type() const
  {
    return field->cast_to_int_type();
  }
unknown's avatar
unknown committed
1721
  enum_field_types field_type() const
1722 1723 1724
  {
    return field->type();
  }
unknown's avatar
unknown committed
1725 1726 1727 1728
  enum_monotonicity_info get_monotonicity_info() const
  {
    return MONOTONIC_STRICT_INCREASING;
  }
1729
  longlong val_int_endpoint(bool left_endp, bool *incl_endp);
1730
  Field *get_tmp_table_field() { return result_field; }
1731
  Field *tmp_table_field(TABLE *t_arg) { return result_field; }
1732 1733 1734
  bool get_date(MYSQL_TIME *ltime,uint fuzzydate);
  bool get_date_result(MYSQL_TIME *ltime,uint fuzzydate);
  bool get_time(MYSQL_TIME *ltime);
unknown's avatar
unknown committed
1735
  bool is_null() { return field->is_null(); }
1736
  void update_null_value();
1737
  Item *get_tmp_table_item(THD *thd);
1738 1739 1740 1741
  bool collect_item_field_processor(uchar * arg);
  bool find_item_in_field_list_processor(uchar *arg);
  bool register_field_in_read_map(uchar *arg);
  bool check_partition_func_processor(uchar *int_arg) {return FALSE;}
unknown's avatar
unknown committed
1742
  void cleanup();
1743 1744 1745 1746
  bool result_as_longlong()
  {
    return field->can_be_compared_as_longlong();
  }
1747
  Item_equal *find_item_equal(COND_EQUAL *cond_equal);
1748 1749 1750 1751
  bool subst_argument_checker(uchar **arg);
  Item *equal_fields_propagator(uchar *arg);
  bool set_no_const_sub(uchar *arg);
  Item *replace_equal_field(uchar *arg);
1752
  inline uint32 max_disp_length() { return field->max_display_length(); }
1753
  Item_field *filed_for_view_update() { return this; }
unknown's avatar
unknown committed
1754
  Item *safe_charset_converter(CHARSET_INFO *tocs);
1755
  int fix_outer_field(THD *thd, Field **field, Item **reference);
1756
  virtual Item *update_value_transformer(uchar *select_arg);
1757
  virtual void print(String *str, enum_query_type query_type);
1758 1759 1760 1761 1762
  bool is_outer_field() const
  {
    DBUG_ASSERT(fixed);
    return field->table->pos_in_table_list->outer_join;
  }
1763
  Field::geometry_type get_geometry_type() const
1764 1765 1766 1767
  {
    DBUG_ASSERT(field_type() == MYSQL_TYPE_GEOMETRY);
    return field->get_geometry_type();
  }
1768 1769
  CHARSET_INFO *charset_for_protocol(void) const
  { return field->charset_for_protocol(); }
unknown's avatar
SCRUM  
unknown committed
1770
  friend class Item_default_value;
unknown's avatar
unknown committed
1771
  friend class Item_insert_value;
unknown's avatar
unknown committed
1772
  friend class st_select_lex_unit;
unknown's avatar
unknown committed
1773 1774
};

1775
class Item_null :public Item_basic_constant
unknown's avatar
unknown committed
1776 1777 1778
{
public:
  Item_null(char *name_par=0)
unknown's avatar
unknown committed
1779 1780 1781 1782 1783
  {
    maybe_null= null_value= TRUE;
    max_length= 0;
    name= name_par ? name_par : (char*) "NULL";
    fixed= 1;
1784
    collation.set(&my_charset_bin, DERIVATION_IGNORABLE);
unknown's avatar
unknown committed
1785
  }
unknown's avatar
unknown committed
1786
  enum Type type() const { return NULL_ITEM; }
1787
  bool eq(const Item *item, bool binary_cmp) const;
1788
  double val_real();
unknown's avatar
unknown committed
1789 1790
  longlong val_int();
  String *val_str(String *str);
unknown's avatar
unknown committed
1791
  my_decimal *val_decimal(my_decimal *);
unknown's avatar
unknown committed
1792
  int save_in_field(Field *field, bool no_conversions);
unknown's avatar
unknown committed
1793
  int save_safe_in_field(Field *field);
unknown's avatar
unknown committed
1794
  bool send(Protocol *protocol, String *str);
1795 1796
  enum Item_result result_type () const { return STRING_RESULT; }
  enum_field_types field_type() const   { return MYSQL_TYPE_NULL; }
unknown's avatar
unknown committed
1797
  bool basic_const_item() const { return 1; }
1798
  Item *clone_item() { return new Item_null(name); }
unknown's avatar
unknown committed
1799
  bool is_null() { return 1; }
1800 1801 1802 1803 1804 1805

  virtual inline void print(String *str, enum_query_type query_type)
  {
    str->append(STRING_WITH_LEN("NULL"));
  }

unknown's avatar
unknown committed
1806
  Item *safe_charset_converter(CHARSET_INFO *tocs);
1807
  bool check_partition_func_processor(uchar *int_arg) {return FALSE;}
unknown's avatar
unknown committed
1808 1809
};

unknown's avatar
unknown committed
1810 1811 1812 1813 1814 1815 1816 1817 1818 1819
class Item_null_result :public Item_null
{
public:
  Field *result_field;
  Item_null_result() : Item_null(), result_field(0) {}
  bool is_result_field() { return result_field != 0; }
  void save_in_result_field(bool no_conversions)
  {
    save_in_field(result_field, no_conversions);
  }
1820
  bool check_partition_func_processor(uchar *int_arg) {return TRUE;}
unknown's avatar
unknown committed
1821
};  
1822 1823 1824

/* Item represents one placeholder ('?') of prepared statement */

1825 1826
class Item_param :public Item,
                  private Settable_routine_parameter
unknown's avatar
unknown committed
1827
{
unknown's avatar
unknown committed
1828 1829 1830 1831
  char cnvbuf[MAX_FIELD_WIDTH];
  String cnvstr;
  Item *cnvitem;

1832
public:
1833 1834 1835
  enum enum_item_param_state
  {
    NO_VALUE, NULL_VALUE, INT_VALUE, REAL_VALUE,
unknown's avatar
unknown committed
1836 1837
    STRING_VALUE, TIME_VALUE, LONG_DATA_VALUE,
    DECIMAL_VALUE
1838 1839
  } state;

1840 1841 1842 1843 1844 1845 1846 1847 1848 1849 1850
  /*
    A buffer for string and long data values. Historically all allocated
    values returned from val_str() were treated as eligible to
    modification. I. e. in some cases Item_func_concat can append it's
    second argument to return value of the first one. Because of that we
    can't return the original buffer holding string data from val_str(),
    and have to have one buffer for data and another just pointing to
    the data. This is the latter one and it's returned from val_str().
    Can not be declared inside the union as it's not a POD type.
  */
  String str_value_ptr;
unknown's avatar
unknown committed
1851
  my_decimal decimal_value;
1852 1853
  union
  {
1854 1855
    longlong integer;
    double   real;
1856 1857 1858 1859 1860 1861 1862 1863 1864
    /*
      Character sets conversion info for string values.
      Character sets of client and connection defined at bind time are used
      for all conversions, even if one of them is later changed (i.e.
      between subsequent calls to mysql_stmt_execute).
    */
    struct CONVERSION_INFO
    {
      CHARSET_INFO *character_set_client;
1865
      CHARSET_INFO *character_set_of_placeholder;
1866 1867 1868
      /*
        This points at character set of connection if conversion
        to it is required (i. e. if placeholder typecode is not BLOB).
1869
        Otherwise it's equal to character_set_client (to simplify
1870 1871 1872 1873
        check in convert_str_value()).
      */
      CHARSET_INFO *final_character_set_of_str_value;
    } cs_info;
1874
    MYSQL_TIME     time;
1875 1876 1877
  } value;

  /* Cached values for virtual methods to save us one switch.  */
unknown's avatar
unknown committed
1878 1879
  enum Item_result item_result_type;
  enum Type item_type;
1880 1881 1882 1883 1884 1885 1886 1887 1888 1889

  /*
    Used when this item is used in a temporary table.
    This is NOT placeholder metadata sent to client, as this value
    is assigned after sending metadata (in setup_one_conversion_function).
    For example in case of 'SELECT ?' you'll get MYSQL_TYPE_STRING both
    in result set and placeholders metadata, no matter what type you will
    supply for this placeholder in mysql_stmt_execute.
  */
  enum enum_field_types param_type;
1890
  /*
1891 1892
    Offset of placeholder inside statement text. Used to create
    no-placeholders version of this statement for the binary log.
1893
  */
1894
  uint pos_in_query;
unknown's avatar
unknown committed
1895

1896 1897 1898
  Item_param(uint pos_in_query_arg);

  enum Item_result result_type () const { return item_result_type; }
unknown's avatar
unknown committed
1899
  enum Type type() const { return item_type; }
1900
  enum_field_types field_type() const { return param_type; }
1901

1902
  double val_real();
unknown's avatar
unknown committed
1903
  longlong val_int();
unknown's avatar
unknown committed
1904
  my_decimal *val_decimal(my_decimal*);
unknown's avatar
unknown committed
1905
  String *val_str(String*);
1906 1907
  bool get_time(MYSQL_TIME *tm);
  bool get_date(MYSQL_TIME *tm, uint fuzzydate);
unknown's avatar
unknown committed
1908
  int  save_in_field(Field *field, bool no_conversions);
1909

unknown's avatar
unknown committed
1910
  void set_null();
1911
  void set_int(longlong i, uint32 max_length_arg);
unknown's avatar
unknown committed
1912
  void set_double(double i);
unknown's avatar
unknown committed
1913
  void set_decimal(const char *str, ulong length);
1914
  void set_decimal(const my_decimal *dv);
1915 1916
  bool set_str(const char *str, ulong length);
  bool set_longdata(const char *str, ulong length);
1917
  void set_time(MYSQL_TIME *tm, timestamp_type type, uint32 max_length_arg);
1918
  bool set_from_user_var(THD *thd, const user_var_entry *entry);
1919
  void reset();
1920 1921 1922 1923 1924 1925 1926 1927
  /*
    Assign placeholder value from bind data.
    Note, that 'len' has different semantics in embedded library (as we
    don't need to check that packet is not broken there). See
    sql_prepare.cc for details.
  */
  void (*set_param_func)(Item_param *param, uchar **pos, ulong len);

1928 1929 1930
  const String *query_val_str(String *str) const;

  bool convert_str_value(THD *thd);
1931 1932 1933 1934

  /*
    If value for parameter was not set we treat it as non-const
    so noone will use parameters value in fix_fields still
1935 1936 1937
    parameter is constant during execution.
  */
  virtual table_map used_tables() const
1938
  { return state != NO_VALUE ? (table_map)0 : PARAM_TABLE_BIT; }
1939
  virtual void print(String *str, enum_query_type query_type);
1940 1941
  bool is_null()
  { DBUG_ASSERT(state != NO_VALUE); return state == NULL_VALUE; }
1942 1943 1944 1945 1946 1947 1948 1949 1950 1951 1952
  bool basic_const_item() const;
  /*
    This method is used to make a copy of a basic constant item when
    propagating constants in the optimizer. The reason to create a new
    item and not use the existing one is not precisely known (2005/04/16).
    Probably we are trying to preserve tree structure of items, in other
    words, avoid pointing at one item from two different nodes of the tree.
    Return a new basic constant item if parameter value is a basic
    constant, assert otherwise. This method is called only if
    basic_const_item returned TRUE.
  */
1953
  Item *safe_charset_converter(CHARSET_INFO *tocs);
1954
  Item *clone_item();
1955 1956 1957 1958 1959 1960
  /*
    Implement by-value equality evaluation if parameter value
    is set and is a basic constant (integer, real or string).
    Otherwise return FALSE.
  */
  bool eq(const Item *item, bool binary_cmp) const;
1961 1962
  /** Item is a argument to a limit clause. */
  bool limit_clause_param;
unknown's avatar
unknown committed
1963
  void set_param_type_and_swap_value(Item_param *from);
1964 1965 1966 1967 1968 1969 1970 1971 1972 1973 1974 1975 1976 1977 1978 1979 1980 1981 1982

private:
  virtual inline Settable_routine_parameter *
    get_settable_routine_parameter()
  {
    return this;
  }

  virtual bool set_value(THD *thd, sp_rcontext *ctx, Item **it);

  virtual void set_out_param_info(Send_field *info);

public:
  virtual const Send_field *get_out_param_info() const;

  virtual void make_field(Send_field *field);

private:
  Send_field *m_out_param_info;
unknown's avatar
unknown committed
1983
};
unknown's avatar
unknown committed
1984

1985

1986
class Item_int :public Item_num
unknown's avatar
unknown committed
1987 1988
{
public:
1989
  longlong value;
1990 1991
  Item_int(int32 i,uint length= MY_INT32_NUM_DECIMAL_DIGITS)
    :value((longlong) i)
1992
    { max_length=length; fixed= 1; }
1993 1994
  Item_int(longlong i,uint length= MY_INT64_NUM_DECIMAL_DIGITS)
    :value(i)
unknown's avatar
unknown committed
1995
    { max_length=length; fixed= 1; }
1996 1997
  Item_int(ulonglong i, uint length= MY_INT64_NUM_DECIMAL_DIGITS)
    :value((longlong)i)
1998
    { max_length=length; fixed= 1; unsigned_flag= 1; }
unknown's avatar
unknown committed
1999
  Item_int(const char *str_arg,longlong i,uint length) :value(i)
2000
    { max_length=length; name=(char*) str_arg; fixed= 1; }
unknown's avatar
unknown committed
2001
  Item_int(const char *str_arg, uint length=64);
unknown's avatar
unknown committed
2002
  enum Type type() const { return INT_ITEM; }
2003 2004
  enum Item_result result_type () const { return INT_RESULT; }
  enum_field_types field_type() const { return MYSQL_TYPE_LONGLONG; }
2005
  longlong val_int() { DBUG_ASSERT(fixed == 1); return value; }
2006
  double val_real() { DBUG_ASSERT(fixed == 1); return (double) value; }
unknown's avatar
unknown committed
2007
  my_decimal *val_decimal(my_decimal *);
unknown's avatar
unknown committed
2008
  String *val_str(String*);
unknown's avatar
unknown committed
2009
  int save_in_field(Field *field, bool no_conversions);
unknown's avatar
unknown committed
2010
  bool basic_const_item() const { return 1; }
2011
  Item *clone_item() { return new Item_int(name,value,max_length); }
2012
  virtual void print(String *str, enum_query_type query_type);
unknown's avatar
unknown committed
2013
  Item_num *neg() { value= -value; return this; }
unknown's avatar
unknown committed
2014 2015
  uint decimal_precision() const
  { return (uint)(max_length - test(value < 0)); }
2016
  bool eq(const Item *, bool binary_cmp) const;
unknown's avatar
unknown committed
2017
  bool check_partition_func_processor(uchar *bool_arg) { return FALSE;}
unknown's avatar
unknown committed
2018 2019 2020
};


unknown's avatar
unknown committed
2021 2022 2023
class Item_uint :public Item_int
{
public:
unknown's avatar
unknown committed
2024
  Item_uint(const char *str_arg, uint length);
2025
  Item_uint(ulonglong i) :Item_int((ulonglong) i, 10) {}
2026
  Item_uint(const char *str_arg, longlong i, uint length);
2027
  double val_real()
2028
    { DBUG_ASSERT(fixed == 1); return ulonglong2double((ulonglong)value); }
unknown's avatar
unknown committed
2029
  String *val_str(String*);
2030
  Item *clone_item() { return new Item_uint(name, value, max_length); }
unknown's avatar
unknown committed
2031
  int save_in_field(Field *field, bool no_conversions);
2032
  virtual void print(String *str, enum_query_type query_type);
unknown's avatar
unknown committed
2033
  Item_num *neg ();
unknown's avatar
unknown committed
2034
  uint decimal_precision() const { return max_length; }
unknown's avatar
unknown committed
2035
  bool check_partition_func_processor(uchar *bool_arg) { return FALSE;}
unknown's avatar
unknown committed
2036 2037 2038
};


unknown's avatar
unknown committed
2039 2040 2041 2042 2043 2044 2045 2046 2047 2048 2049 2050
/* decimal (fixed point) constant */
class Item_decimal :public Item_num
{
protected:
  my_decimal decimal_value;
public:
  Item_decimal(const char *str_arg, uint length, CHARSET_INFO *charset);
  Item_decimal(const char *str, const my_decimal *val_arg,
               uint decimal_par, uint length);
  Item_decimal(my_decimal *value_par);
  Item_decimal(longlong val, bool unsig);
  Item_decimal(double val, int precision, int scale);
2051
  Item_decimal(const uchar *bin, int precision, int scale);
unknown's avatar
unknown committed
2052 2053 2054 2055 2056 2057 2058 2059 2060 2061

  enum Type type() const { return DECIMAL_ITEM; }
  enum Item_result result_type () const { return DECIMAL_RESULT; }
  enum_field_types field_type() const { return MYSQL_TYPE_NEWDECIMAL; }
  longlong val_int();
  double val_real();
  String *val_str(String*);
  my_decimal *val_decimal(my_decimal *val) { return &decimal_value; }
  int save_in_field(Field *field, bool no_conversions);
  bool basic_const_item() const { return 1; }
2062
  Item *clone_item()
unknown's avatar
unknown committed
2063 2064 2065
  {
    return new Item_decimal(name, &decimal_value, decimals, max_length);
  }
2066
  virtual void print(String *str, enum_query_type query_type);
unknown's avatar
unknown committed
2067 2068 2069 2070 2071 2072
  Item_num *neg()
  {
    my_decimal_neg(&decimal_value);
    unsigned_flag= !decimal_value.sign();
    return this;
  }
unknown's avatar
unknown committed
2073
  uint decimal_precision() const { return decimal_value.precision(); }
2074
  bool eq(const Item *, bool binary_cmp) const;
2075
  void set_decimal_value(my_decimal *value_par);
unknown's avatar
unknown committed
2076
  bool check_partition_func_processor(uchar *bool_arg) { return FALSE;}
unknown's avatar
unknown committed
2077 2078
};

2079

unknown's avatar
unknown committed
2080
class Item_float :public Item_num
unknown's avatar
unknown committed
2081
{
2082
  char *presentation;
unknown's avatar
unknown committed
2083
public:
2084
  double value;
unknown's avatar
unknown committed
2085
  // Item_real() :value(0) {}
unknown's avatar
unknown committed
2086 2087
  Item_float(const char *str_arg, uint length);
  Item_float(const char *str,double val_arg,uint decimal_par,uint length)
unknown's avatar
unknown committed
2088 2089
    :value(val_arg)
  {
2090
    presentation= name=(char*) str;
unknown's avatar
unknown committed
2091
    decimals=(uint8) decimal_par;
unknown's avatar
unknown committed
2092
    max_length=length;
unknown's avatar
unknown committed
2093
    fixed= 1;
unknown's avatar
unknown committed
2094
  }
2095 2096 2097 2098 2099
  Item_float(double value_par, uint decimal_par) :presentation(0), value(value_par)
  {
    decimals= (uint8) decimal_par;
    fixed= 1;
  }
unknown's avatar
unknown committed
2100
  int save_in_field(Field *field, bool no_conversions);
unknown's avatar
unknown committed
2101
  enum Type type() const { return REAL_ITEM; }
2102
  enum_field_types field_type() const { return MYSQL_TYPE_DOUBLE; }
2103
  double val_real() { DBUG_ASSERT(fixed == 1); return value; }
2104 2105 2106
  longlong val_int()
  {
    DBUG_ASSERT(fixed == 1);
2107 2108 2109 2110 2111 2112 2113 2114
    if (value <= (double) LONGLONG_MIN)
    {
       return LONGLONG_MIN;
    }
    else if (value >= (double) (ulonglong) LONGLONG_MAX)
    {
      return LONGLONG_MAX;
    }
2115
    return (longlong) rint(value);
2116
  }
unknown's avatar
unknown committed
2117
  String *val_str(String*);
unknown's avatar
unknown committed
2118
  my_decimal *val_decimal(my_decimal *);
unknown's avatar
unknown committed
2119
  bool basic_const_item() const { return 1; }
2120
  Item *clone_item()
unknown's avatar
unknown committed
2121
  { return new Item_float(name, value, decimals, max_length); }
unknown's avatar
unknown committed
2122
  Item_num *neg() { value= -value; return this; }
2123
  virtual void print(String *str, enum_query_type query_type);
2124
  bool eq(const Item *, bool binary_cmp) const;
unknown's avatar
unknown committed
2125 2126 2127
};


unknown's avatar
unknown committed
2128
class Item_static_float_func :public Item_float
2129 2130 2131
{
  const char *func_name;
public:
unknown's avatar
unknown committed
2132
  Item_static_float_func(const char *str, double val_arg, uint decimal_par,
2133
                        uint length)
unknown's avatar
unknown committed
2134
    :Item_float(NullS, val_arg, decimal_par, length), func_name(str)
2135
  {}
2136 2137 2138 2139 2140 2141

  virtual inline void print(String *str, enum_query_type query_type)
  {
    str->append(func_name);
  }

2142
  Item *safe_charset_converter(CHARSET_INFO *tocs);
2143 2144 2145
};


2146
class Item_string :public Item_basic_constant
unknown's avatar
unknown committed
2147 2148
{
public:
unknown's avatar
unknown committed
2149
  Item_string(const char *str,uint length,
2150 2151
              CHARSET_INFO *cs, Derivation dv= DERIVATION_COERCIBLE,
              uint repertoire= MY_REPERTOIRE_UNICODE30)
2152
    : m_cs_specified(FALSE)
unknown's avatar
unknown committed
2153
  {
2154 2155
    str_value.set_or_copy_aligned(str, length, cs);
    collation.set(cs, dv, repertoire);
2156 2157 2158 2159
    /*
      We have to have a different max_length than 'length' here to
      ensure that we get the right length if we do use the item
      to create a new table. In this case max_length must be the maximum
unknown's avatar
unknown committed
2160
      number of chars for a string of this type because we in Create_field::
2161 2162
      divide the max_length with mbmaxlen).
    */
2163
    max_length= str_value.numchars()*cs->mbmaxlen;
unknown's avatar
unknown committed
2164
    set_name(str, length, cs);
unknown's avatar
unknown committed
2165
    decimals=NOT_FIXED_DEC;
2166 2167
    // it is constant => can be used without fix_fields (and frequently used)
    fixed= 1;
unknown's avatar
unknown committed
2168
  }
2169 2170
  /* Just create an item and do not fill string representation */
  Item_string(CHARSET_INFO *cs, Derivation dv= DERIVATION_COERCIBLE)
2171
    : m_cs_specified(FALSE)
2172 2173 2174 2175 2176 2177 2178
  {
    collation.set(cs, dv);
    max_length= 0;
    set_name(NULL, 0, cs);
    decimals= NOT_FIXED_DEC;
    fixed= 1;
  }
2179
  Item_string(const char *name_par, const char *str, uint length,
2180 2181
              CHARSET_INFO *cs, Derivation dv= DERIVATION_COERCIBLE,
              uint repertoire= MY_REPERTOIRE_UNICODE30)
2182
    : m_cs_specified(FALSE)
unknown's avatar
unknown committed
2183
  {
2184 2185
    str_value.set_or_copy_aligned(str, length, cs);
    collation.set(cs, dv, repertoire);
2186
    max_length= str_value.numchars()*cs->mbmaxlen;
2187
    set_name(name_par, 0, cs);
unknown's avatar
unknown committed
2188
    decimals=NOT_FIXED_DEC;
2189 2190
    // it is constant => can be used without fix_fields (and frequently used)
    fixed= 1;
unknown's avatar
unknown committed
2191
  }
2192 2193 2194 2195 2196 2197 2198 2199 2200
  /*
    This is used in stored procedures to avoid memory leaks and
    does a deep copy of its argument.
  */
  void set_str_with_copy(const char *str_arg, uint length_arg)
  {
    str_value.copy(str_arg, length_arg, collation.collation);
    max_length= str_value.numchars() * collation.collation->mbmaxlen;
  }
2201 2202 2203 2204 2205 2206
  void set_repertoire_from_value()
  {
    collation.repertoire= my_string_repertoire(str_value.charset(),
                                               str_value.ptr(),
                                               str_value.length());
  }
unknown's avatar
unknown committed
2207
  enum Type type() const { return STRING_ITEM; }
2208 2209
  double val_real();
  longlong val_int();
2210 2211 2212 2213 2214
  String *val_str(String*)
  {
    DBUG_ASSERT(fixed == 1);
    return (String*) &str_value;
  }
unknown's avatar
unknown committed
2215
  my_decimal *val_decimal(my_decimal *);
unknown's avatar
unknown committed
2216
  int save_in_field(Field *field, bool no_conversions);
unknown's avatar
unknown committed
2217
  enum Item_result result_type () const { return STRING_RESULT; }
2218
  enum_field_types field_type() const { return MYSQL_TYPE_VARCHAR; }
unknown's avatar
unknown committed
2219
  bool basic_const_item() const { return 1; }
2220
  bool eq(const Item *item, bool binary_cmp) const;
2221
  Item *clone_item() 
2222
  {
2223
    return new Item_string(name, str_value.ptr(), 
unknown's avatar
unknown committed
2224
    			   str_value.length(), collation.collation);
2225
  }
unknown's avatar
unknown committed
2226
  Item *safe_charset_converter(CHARSET_INFO *tocs);
2227 2228 2229 2230 2231
  inline void append(char *str, uint length)
  {
    str_value.append(str, length);
    max_length= str_value.numchars() * collation.collation->mbmaxlen;
  }
2232
  virtual void print(String *str, enum_query_type query_type);
2233
  bool check_partition_func_processor(uchar *int_arg) {return FALSE;}
2234 2235 2236 2237 2238 2239 2240 2241 2242 2243 2244 2245 2246 2247 2248 2249 2250 2251 2252 2253 2254 2255 2256 2257 2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272 2273 2274 2275

  /**
    Return TRUE if character-set-introducer was explicitly specified in the
    original query for this item (text literal).

    This operation is to be called from Item_string::print(). The idea is
    that when a query is generated (re-constructed) from the Item-tree,
    character-set-introducers should appear only for those literals, where
    they were explicitly specified by the user. Otherwise, that may lead to
    loss collation information (character set introducers implies default
    collation for the literal).

    Basically, that makes sense only for views and hopefully will be gone
    one day when we start using original query as a view definition.

    @return This operation returns the value of m_cs_specified attribute.
      @retval TRUE if character set introducer was explicitly specified in
      the original query.
      @retval FALSE otherwise.
  */
  inline bool is_cs_specified() const
  {
    return m_cs_specified;
  }

  /**
    Set the value of m_cs_specified attribute.

    m_cs_specified attribute shows whether character-set-introducer was
    explicitly specified in the original query for this text literal or
    not. The attribute makes sense (is used) only for views.

    This operation is to be called from the parser during parsing an input
    query.
  */
  inline void set_cs_specified(bool cs_specified)
  {
    m_cs_specified= cs_specified;
  }

private:
  bool m_cs_specified;
unknown's avatar
unknown committed
2276 2277
};

2278

2279 2280 2281 2282 2283
longlong 
longlong_from_string_with_check (CHARSET_INFO *cs, const char *cptr, char *end);
double 
double_from_string_with_check (CHARSET_INFO *cs, const char *cptr, char *end);

2284 2285 2286 2287 2288 2289 2290 2291 2292
class Item_static_string_func :public Item_string
{
  const char *func_name;
public:
  Item_static_string_func(const char *name_par, const char *str, uint length,
                          CHARSET_INFO *cs,
                          Derivation dv= DERIVATION_COERCIBLE)
    :Item_string(NullS, str, length, cs, dv), func_name(name_par)
  {}
2293
  Item *safe_charset_converter(CHARSET_INFO *tocs);
2294 2295 2296 2297 2298 2299

  virtual inline void print(String *str, enum_query_type query_type)
  {
    str->append(func_name);
  }

2300
  bool check_partition_func_processor(uchar *int_arg) {return TRUE;}
2301 2302 2303
};


unknown's avatar
unknown committed
2304
/* for show tables */
2305
class Item_partition_func_safe_string: public Item_string
unknown's avatar
unknown committed
2306 2307
{
public:
2308 2309 2310 2311
  Item_partition_func_safe_string(const char *name, uint length,
                                  CHARSET_INFO *cs= NULL):
    Item_string(name, length, cs)
  {}
unknown's avatar
unknown committed
2312 2313
};

2314 2315 2316 2317 2318 2319 2320 2321 2322 2323 2324 2325 2326 2327 2328 2329 2330 2331 2332 2333 2334 2335 2336 2337

class Item_return_date_time :public Item_partition_func_safe_string
{
  enum_field_types date_time_field_type;
public:
  Item_return_date_time(const char *name_arg, enum_field_types field_type_arg)
    :Item_partition_func_safe_string(name_arg, 0, &my_charset_bin),
     date_time_field_type(field_type_arg)
  { }
  enum_field_types field_type() const { return date_time_field_type; }
};


class Item_blob :public Item_partition_func_safe_string
{
public:
  Item_blob(const char *name, uint length) :
    Item_partition_func_safe_string(name, length, &my_charset_bin)
  { max_length= length; }
  enum Type type() const { return TYPE_HOLDER; }
  enum_field_types field_type() const { return MYSQL_TYPE_BLOB; }
};


2338 2339
/**
  Item_empty_string -- is a utility class to put an item into List<Item>
2340
  which is then used in protocol.send_result_set_metadata() when sending SHOW output to
2341 2342 2343
  the client.
*/

2344
class Item_empty_string :public Item_partition_func_safe_string
unknown's avatar
unknown committed
2345 2346
{
public:
2347
  Item_empty_string(const char *header,uint length, CHARSET_INFO *cs= NULL) :
2348
    Item_partition_func_safe_string("",0, cs ? cs : &my_charset_utf8_general_ci)
2349
    { name=(char*) header; max_length= length * collation.collation->mbmaxlen; }
2350
  void make_field(Send_field *field);
unknown's avatar
unknown committed
2351 2352
};

2353

2354 2355 2356 2357
class Item_return_int :public Item_int
{
  enum_field_types int_field_type;
public:
2358
  Item_return_int(const char *name_arg, uint length,
2359 2360
		  enum_field_types field_type_arg, longlong value= 0)
    :Item_int(name_arg, value, length), int_field_type(field_type_arg)
2361 2362 2363 2364 2365 2366 2367
  {
    unsigned_flag=1;
  }
  enum_field_types field_type() const { return int_field_type; }
};


2368
class Item_hex_string: public Item_basic_constant
unknown's avatar
unknown committed
2369 2370
{
public:
Georgi Kodinov's avatar
Georgi Kodinov committed
2371
  Item_hex_string();
unknown's avatar
unknown committed
2372
  Item_hex_string(const char *str,uint str_length);
unknown's avatar
unknown committed
2373
  enum Type type() const { return VARBIN_ITEM; }
2374
  double val_real()
unknown's avatar
unknown committed
2375 2376 2377 2378
  { 
    DBUG_ASSERT(fixed == 1); 
    return (double) (ulonglong) Item_hex_string::val_int();
  }
unknown's avatar
unknown committed
2379
  longlong val_int();
unknown's avatar
unknown committed
2380
  bool basic_const_item() const { return 1; }
2381
  String *val_str(String*) { DBUG_ASSERT(fixed == 1); return &str_value; }
unknown's avatar
unknown committed
2382
  my_decimal *val_decimal(my_decimal *);
unknown's avatar
unknown committed
2383
  int save_in_field(Field *field, bool no_conversions);
2384
  enum Item_result result_type () const { return STRING_RESULT; }
2385
  enum Item_result cast_to_int_type() const { return INT_RESULT; }
2386
  enum_field_types field_type() const { return MYSQL_TYPE_VARCHAR; }
2387
  virtual void print(String *str, enum_query_type query_type);
2388
  bool eq(const Item *item, bool binary_cmp) const;
unknown's avatar
unknown committed
2389
  virtual Item *safe_charset_converter(CHARSET_INFO *tocs);
2390
  bool check_partition_func_processor(uchar *int_arg) {return FALSE;}
Georgi Kodinov's avatar
Georgi Kodinov committed
2391 2392
private:
  void hex_string_init(const char *str, uint str_length);
unknown's avatar
unknown committed
2393 2394 2395
};


unknown's avatar
unknown committed
2396 2397 2398 2399 2400 2401
class Item_bin_string: public Item_hex_string
{
public:
  Item_bin_string(const char *str,uint str_length);
};

unknown's avatar
unknown committed
2402 2403 2404 2405 2406
class Item_result_field :public Item	/* Item with result field */
{
public:
  Field *result_field;				/* Save result here */
  Item_result_field() :result_field(0) {}
2407
  // Constructor used for Item_sum/Item_cond_and/or (see Item comment)
2408 2409
  Item_result_field(THD *thd, Item_result_field *item):
    Item(thd, item), result_field(item->result_field)
2410
  {}
unknown's avatar
unknown committed
2411
  ~Item_result_field() {}			/* Required with gcc 2.95 */
2412
  Field *get_tmp_table_field() { return result_field; }
2413
  Field *tmp_table_field(TABLE *t_arg) { return result_field; }
unknown's avatar
unknown committed
2414
  table_map used_tables() const { return 1; }
unknown's avatar
unknown committed
2415
  virtual void fix_length_and_dec()=0;
unknown's avatar
unknown committed
2416 2417 2418 2419 2420 2421
  void set_result_field(Field *field) { result_field= field; }
  bool is_result_field() { return 1; }
  void save_in_result_field(bool no_conversions)
  {
    save_in_field(result_field, no_conversions);
  }
2422
  void cleanup();
2423 2424 2425 2426 2427 2428 2429 2430 2431 2432 2433 2434 2435 2436 2437 2438 2439
  /*
    This method is used for debug purposes to print the name of an
    item to the debug log. The second use of this method is as
    a helper function of print() and error messages, where it is
    applicable. To suit both goals it should return a meaningful,
    distinguishable and sintactically correct string. This method
    should not be used for runtime type identification, use enum
    {Sum}Functype and Item_func::functype()/Item_sum::sum_func()
    instead.
    Added here, to the parent class of both Item_func and Item_sum_func.

    NOTE: for Items inherited from Item_sum, func_name() return part of
    function name till first argument (including '(') to make difference in
    names for functions with 'distinct' clause and without 'distinct' and
    also to make printing of items inherited from Item_sum uniform.
  */
  virtual const char *func_name() const= 0;
unknown's avatar
unknown committed
2440 2441 2442 2443 2444
};


class Item_ref :public Item_ident
{
2445 2446
protected:
  void set_properties();
unknown's avatar
unknown committed
2447
public:
2448
  enum Ref_Type { REF, DIRECT_REF, VIEW_REF, OUTER_REF, AGGREGATE_REF };
unknown's avatar
unknown committed
2449
  Field *result_field;			 /* Save result here */
unknown's avatar
unknown committed
2450
  Item **ref;
2451 2452 2453 2454 2455
  Item_ref(Name_resolution_context *context_arg,
           const char *db_arg, const char *table_name_arg,
           const char *field_name_arg)
    :Item_ident(context_arg, db_arg, table_name_arg, field_name_arg),
     result_field(0), ref(0) {}
2456
  /*
2457 2458 2459 2460 2461 2462 2463 2464 2465 2466
    This constructor is used in two scenarios:
    A) *item = NULL
      No initialization is performed, fix_fields() call will be necessary.
      
    B) *item points to an Item this Item_ref will refer to. This is 
      used for GROUP BY. fix_fields() will not be called in this case,
      so we call set_properties to make this item "fixed". set_properties
      performs a subset of action Item_ref::fix_fields does, and this subset
      is enough for Item_ref's used in GROUP BY.
    
2467 2468 2469
    TODO we probably fix a superset of problems like in BUG#6658. Check this 
         with Bar, and if we have a more broader set of problems like this.
  */
2470
  Item_ref(Name_resolution_context *context_arg, Item **item,
unknown's avatar
unknown committed
2471 2472
           const char *table_name_arg, const char *field_name_arg,
           bool alias_name_used_arg= FALSE);
2473 2474
  Item_ref(TABLE_LIST *view_arg, Item **item,
           const char *field_name_arg, bool alias_name_used_arg= FALSE);
2475

2476
  /* Constructor need to process subselect with temporary tables (see Item) */
2477 2478
  Item_ref(THD *thd, Item_ref *item)
    :Item_ident(thd, item), result_field(item->result_field), ref(item->ref) {}
unknown's avatar
unknown committed
2479
  enum Type type() const		{ return REF_ITEM; }
2480
  bool eq(const Item *item, bool binary_cmp) const
unknown's avatar
unknown committed
2481 2482 2483 2484
  { 
    Item *it= ((Item *) item)->real_item();
    return ref && (*ref)->eq(it, binary_cmp);
  }
unknown's avatar
unknown committed
2485 2486 2487 2488 2489 2490
  double val_real();
  longlong val_int();
  my_decimal *val_decimal(my_decimal *);
  bool val_bool();
  String *val_str(String* tmp);
  bool is_null();
2491
  bool get_date(MYSQL_TIME *ltime,uint fuzzydate);
2492 2493 2494
  double val_result();
  longlong val_int_result();
  String *str_result(String* tmp);
unknown's avatar
unknown committed
2495 2496
  my_decimal *val_decimal_result(my_decimal *);
  bool val_bool_result();
2497
  bool is_null_result();
2498
  bool send(Protocol *prot, String *tmp);
2499 2500
  void make_field(Send_field *field);
  bool fix_fields(THD *, Item **);
2501
  int save_in_field(Field *field, bool no_conversions);
unknown's avatar
unknown committed
2502
  void save_org_in_field(Field *field);
unknown's avatar
unknown committed
2503
  enum Item_result result_type () const { return (*ref)->result_type(); }
2504
  enum_field_types field_type() const   { return (*ref)->field_type(); }
unknown's avatar
unknown committed
2505 2506
  Field *get_tmp_table_field()
  { return result_field ? result_field : (*ref)->get_tmp_table_field(); }
unknown's avatar
unknown committed
2507
  Item *get_tmp_table_item(THD *thd);
2508
  table_map used_tables() const		
2509
  {
2510 2511
    return depended_from ? OUTER_REF_TABLE_BIT : (*ref)->used_tables(); 
  }
unknown's avatar
unknown committed
2512 2513 2514 2515 2516
  void update_used_tables() 
  { 
    if (!depended_from) 
      (*ref)->update_used_tables(); 
  }
2517
  table_map not_null_tables() const { return (*ref)->not_null_tables(); }
2518
  void set_result_field(Field *field)	{ result_field= field; }
unknown's avatar
unknown committed
2519 2520 2521 2522 2523
  bool is_result_field() { return 1; }
  void save_in_result_field(bool no_conversions)
  {
    (*ref)->save_in_field(result_field, no_conversions);
  }
unknown's avatar
unknown committed
2524 2525
  Item *real_item()
  {
unknown's avatar
unknown committed
2526
    return ref ? (*ref)->real_item() : this;
2527
  }
2528
  bool walk(Item_processor processor, bool walk_subquery, uchar *arg)
2529 2530 2531 2532
  {
    return (*ref)->walk(processor, walk_subquery, arg) ||
           (this->*processor)(arg);
  }
2533
  virtual void print(String *str, enum_query_type query_type);
2534 2535 2536 2537
  bool result_as_longlong()
  {
    return (*ref)->result_as_longlong();
  }
unknown's avatar
unknown committed
2538
  void cleanup();
2539 2540
  Item_field *filed_for_view_update()
    { return (*ref)->filed_for_view_update(); }
2541
  virtual Ref_Type ref_type() { return REF; }
2542 2543 2544 2545 2546 2547 2548 2549 2550 2551 2552 2553 2554 2555 2556 2557 2558 2559 2560 2561 2562 2563 2564 2565 2566 2567 2568 2569

  // Row emulation: forwarding of ROW-related calls to ref
  uint cols()
  {
    return ref && result_type() == ROW_RESULT ? (*ref)->cols() : 1;
  }
  Item* element_index(uint i)
  {
    return ref && result_type() == ROW_RESULT ? (*ref)->element_index(i) : this;
  }
  Item** addr(uint i)
  {
    return ref && result_type() == ROW_RESULT ? (*ref)->addr(i) : 0;
  }
  bool check_cols(uint c)
  {
    return ref && result_type() == ROW_RESULT ? (*ref)->check_cols(c) 
                                              : Item::check_cols(c);
  }
  bool null_inside()
  {
    return ref && result_type() == ROW_RESULT ? (*ref)->null_inside() : 0;
  }
  void bring_value()
  { 
    if (ref && result_type() == ROW_RESULT)
      (*ref)->bring_value();
  }
2570 2571 2572 2573 2574
  bool get_time(MYSQL_TIME *ltime)
  {
    DBUG_ASSERT(fixed);
    return (*ref)->get_time(ltime);
  }
2575
  virtual bool basic_const_item() const { return ref && (*ref)->basic_const_item(); }
2576 2577 2578 2579 2580 2581
  bool is_outer_field() const
  {
    DBUG_ASSERT(fixed);
    DBUG_ASSERT(ref);
    return (*ref)->is_outer_field();
  }
2582

unknown's avatar
unknown committed
2583 2584
};

2585

unknown's avatar
unknown committed
2586 2587 2588 2589
/*
  The same as Item_ref, but get value from val_* family of method to get
  value of item on which it referred instead of result* family.
*/
2590 2591 2592
class Item_direct_ref :public Item_ref
{
public:
2593 2594
  Item_direct_ref(Name_resolution_context *context_arg, Item **item,
                  const char *table_name_arg,
unknown's avatar
unknown committed
2595 2596 2597 2598 2599
                  const char *field_name_arg,
                  bool alias_name_used_arg= FALSE)
    :Item_ref(context_arg, item, table_name_arg,
              field_name_arg, alias_name_used_arg)
  {}
2600 2601
  /* Constructor need to process subselect with temporary tables (see Item) */
  Item_direct_ref(THD *thd, Item_direct_ref *item) : Item_ref(thd, item) {}
2602 2603 2604 2605 2606 2607
  Item_direct_ref(TABLE_LIST *view_arg, Item **item,
                  const char *field_name_arg,
                  bool alias_name_used_arg= FALSE)
    :Item_ref(view_arg, item, field_name_arg,
              alias_name_used_arg)
  {}
2608

unknown's avatar
unknown committed
2609 2610 2611 2612 2613 2614
  double val_real();
  longlong val_int();
  String *val_str(String* tmp);
  my_decimal *val_decimal(my_decimal *);
  bool val_bool();
  bool is_null();
2615
  bool get_date(MYSQL_TIME *ltime,uint fuzzydate);
2616
  virtual Ref_Type ref_type() { return DIRECT_REF; }
2617 2618
};

2619 2620 2621 2622 2623 2624 2625 2626 2627 2628 2629 2630 2631 2632
/*
  Class for view fields, the same as Item_direct_ref, but call fix_fields
  of reference if it is not called yet
*/
class Item_direct_view_ref :public Item_direct_ref
{
public:
  Item_direct_view_ref(Name_resolution_context *context_arg, Item **item,
                  const char *table_name_arg,
                  const char *field_name_arg)
    :Item_direct_ref(context_arg, item, table_name_arg, field_name_arg) {}
  /* Constructor need to process subselect with temporary tables (see Item) */
  Item_direct_view_ref(THD *thd, Item_direct_ref *item)
    :Item_direct_ref(thd, item) {}
2633 2634 2635 2636
  Item_direct_view_ref(TABLE_LIST *view_arg, Item **item,
                       const char *field_name_arg)
    :Item_direct_ref(view_arg, item, field_name_arg)
  {}
2637 2638

  bool fix_fields(THD *, Item **);
2639
  bool eq(const Item *item, bool binary_cmp) const;
unknown's avatar
unknown committed
2640 2641 2642 2643 2644 2645
  Item *get_tmp_table_item(THD *thd)
  {
    Item *item= Item_ref::get_tmp_table_item(thd);
    item->name= name;
    return item;
  }
2646
  virtual Ref_Type ref_type() { return VIEW_REF; }
2647 2648
};

2649

2650 2651 2652 2653 2654 2655 2656 2657 2658 2659 2660
/*
  Class for outer fields.
  An object of this class is created when the select where the outer field was
  resolved is a grouping one. After it has been fixed the ref field will point
  to either an Item_ref or an Item_direct_ref object which will be used to
  access the field.
  See also comments for the fix_inner_refs() and the
  Item_field::fix_outer_field() functions.
*/

class Item_sum;
2661 2662 2663
class Item_outer_ref :public Item_direct_ref
{
public:
2664 2665 2666 2667 2668 2669 2670 2671
  Item *outer_ref;
  /* The aggregate function under which this outer ref is used, if any. */
  Item_sum *in_sum_func;
  /*
    TRUE <=> that the outer_ref is already present in the select list
    of the outer select.
  */
  bool found_in_select_list;
2672 2673 2674
  Item_outer_ref(Name_resolution_context *context_arg,
                 Item_field *outer_field_arg)
    :Item_direct_ref(context_arg, 0, outer_field_arg->table_name,
2675 2676 2677
                     outer_field_arg->field_name),
    outer_ref(outer_field_arg), in_sum_func(0),
    found_in_select_list(0)
2678
  {
2679
    ref= &outer_ref;
2680 2681 2682
    set_properties();
    fixed= 0;
  }
2683 2684 2685 2686 2687 2688 2689
  Item_outer_ref(Name_resolution_context *context_arg, Item **item,
                 const char *table_name_arg, const char *field_name_arg,
                 bool alias_name_used_arg)
    :Item_direct_ref(context_arg, item, table_name_arg, field_name_arg,
                     alias_name_used_arg),
    outer_ref(0), in_sum_func(0), found_in_select_list(1)
  {}
2690 2691
  void save_in_result_field(bool no_conversions)
  {
2692
    outer_ref->save_org_in_field(result_field);
2693 2694 2695 2696 2697 2698 2699 2700 2701 2702
  }
  bool fix_fields(THD *, Item **);
  table_map used_tables() const
  {
    return (*ref)->const_item() ? 0 : OUTER_REF_TABLE_BIT;
  }
  virtual Ref_Type ref_type() { return OUTER_REF; }
};


2703
class Item_in_subselect;
2704

2705 2706 2707 2708 2709 2710 2711 2712 2713 2714

/*
  An object of this class:
   - Converts val_XXX() calls to ref->val_XXX_result() calls, like Item_ref.
   - Sets owner->was_null=TRUE if it has returned a NULL value from any
     val_XXX() function. This allows to inject an Item_ref_null_helper
     object into subquery and then check if the subquery has produced a row
     with NULL value.
*/

2715 2716 2717 2718 2719
class Item_ref_null_helper: public Item_ref
{
protected:
  Item_in_subselect* owner;
public:
2720 2721 2722 2723 2724
  Item_ref_null_helper(Name_resolution_context *context_arg,
                       Item_in_subselect* master, Item **item,
		       const char *table_name_arg, const char *field_name_arg)
    :Item_ref(context_arg, item, table_name_arg, field_name_arg),
     owner(master) {}
2725
  double val_real();
2726 2727
  longlong val_int();
  String* val_str(String* s);
unknown's avatar
unknown committed
2728 2729
  my_decimal *val_decimal(my_decimal *);
  bool val_bool();
2730
  bool get_date(MYSQL_TIME *ltime, uint fuzzydate);
2731
  virtual void print(String *str, enum_query_type query_type);
2732 2733 2734 2735 2736 2737 2738 2739 2740
  /*
    we add RAND_TABLE_BIT to prevent moving this item from HAVING to WHERE
  */
  table_map used_tables() const
  {
    return (depended_from ?
            OUTER_REF_TABLE_BIT :
            (*ref)->used_tables() | RAND_TABLE_BIT);
  }
2741 2742
};

2743
/*
2744
  The following class is used to optimize comparing of date and bigint columns
2745 2746 2747 2748 2749
  We need to save the original item ('ref') to be able to call
  ref->save_in_field(). This is used to create index search keys.
  
  An instance of Item_int_with_ref may have signed or unsigned integer value.
  
2750 2751 2752 2753 2754 2755
*/

class Item_int_with_ref :public Item_int
{
  Item *ref;
public:
unknown's avatar
unknown committed
2756 2757
  Item_int_with_ref(longlong i, Item *ref_arg, my_bool unsigned_arg) :
    Item_int(i), ref(ref_arg)
2758
  {
unknown's avatar
unknown committed
2759
    unsigned_flag= unsigned_arg;
2760
  }
unknown's avatar
unknown committed
2761
  int save_in_field(Field *field, bool no_conversions)
2762
  {
2763
    return ref->save_in_field(field, no_conversions);
2764
  }
2765
  Item *clone_item();
2766
  virtual Item *real_item() { return ref; }
2767 2768
};

2769
#ifdef MYSQL_SERVER
2770
#include "gstream.h"
unknown's avatar
unknown committed
2771
#include "spatial.h"
unknown's avatar
unknown committed
2772 2773
#include "item_sum.h"
#include "item_func.h"
2774
#include "item_row.h"
unknown's avatar
unknown committed
2775 2776
#include "item_cmpfunc.h"
#include "item_strfunc.h"
2777
#include "item_geofunc.h"
unknown's avatar
unknown committed
2778
#include "item_timefunc.h"
2779
#include "item_subselect.h"
2780
#include "item_xmlfunc.h"
2781
#include "item_create.h"
2782
#endif
unknown's avatar
unknown committed
2783

2784 2785 2786 2787 2788 2789 2790 2791 2792 2793 2794 2795 2796 2797 2798 2799 2800 2801 2802 2803 2804
/**
  Base class to implement typed value caching Item classes

  Item_copy_ classes are very similar to the corresponding Item_
  classes (e.g. Item_copy_int is similar to Item_int) but they add
  the following additional functionality to Item_ :
    1. Nullability
    2. Possibility to store the value not only on instantiation time,
       but also later.
  Item_copy_ classes are a functionality subset of Item_cache_ 
  classes, as e.g. they don't support comparisons with the original Item
  as Item_cache_ classes do.
  Item_copy_ classes are used in GROUP BY calculation.
  TODO: Item_copy should be made an abstract interface and Item_copy_
  classes should inherit both the respective Item_ class and the interface.
  Ideally we should drop Item_copy_ classes altogether and merge 
  their functionality to Item_cache_ (and these should be made to inherit
  from Item_).
*/

class Item_copy :public Item
unknown's avatar
unknown committed
2805
{
2806 2807 2808 2809 2810 2811
protected:  

  /**
    Stores the type of the resulting field that would be used to store the data
    in the cache. This is to avoid calls to the original item.
  */
2812
  enum enum_field_types cached_field_type;
2813 2814

  /** The original item that is copied */
unknown's avatar
unknown committed
2815
  Item *item;
2816 2817 2818 2819 2820 2821 2822 2823 2824 2825 2826 2827 2828 2829

  /**
    Stores the result type of the original item, so it can be returned
    without calling the original item's method
  */
  Item_result cached_result_type;

  /**
    Constructor of the Item_copy class

    stores metadata information about the original class as well as a 
    pointer to it.
  */
  Item_copy(Item *i)
unknown's avatar
unknown committed
2830
  {
2831
    item= i;
unknown's avatar
unknown committed
2832 2833 2834 2835
    null_value=maybe_null=item->maybe_null;
    decimals=item->decimals;
    max_length=item->max_length;
    name=item->name;
2836
    cached_field_type= item->field_type();
2837 2838
    cached_result_type= item->result_type();
    unsigned_flag= item->unsigned_flag;
2839
    fixed= item->fixed;
2840
    collation.set(item->collation);
unknown's avatar
unknown committed
2841
  }
2842 2843 2844 2845 2846 2847 2848 2849 2850 2851 2852 2853 2854 2855 2856 2857 2858 2859 2860 2861 2862

public:
  /** 
    Factory method to create the appropriate subclass dependent on the type of 
    the original item.

    @param item      the original item.
  */  
  static Item_copy *create (Item *item);

  /** 
    Update the cache with the value of the original item
   
    This is the method that updates the cached value.
    It must be explicitly called by the user of this class to store the value 
    of the orginal item in the cache.
  */  
  virtual void copy() = 0;

  Item *get_item() { return item; }
  /** All of the subclasses should have the same type tag */
unknown's avatar
unknown committed
2863
  enum Type type() const { return COPY_STR_ITEM; }
2864
  enum_field_types field_type() const { return cached_field_type; }
2865 2866 2867 2868 2869 2870 2871 2872 2873 2874 2875 2876 2877 2878 2879 2880 2881 2882 2883 2884 2885 2886 2887 2888 2889 2890 2891 2892 2893 2894 2895 2896 2897 2898 2899 2900 2901 2902 2903 2904 2905 2906 2907 2908 2909 2910 2911 2912 2913
  enum Item_result result_type () const { return cached_result_type; }

  void make_field(Send_field *field) { item->make_field(field); }
  table_map used_tables() const { return (table_map) 1L; }
  bool const_item() const { return 0; }
  bool is_null() { return null_value; }

  /*  
    Override the methods below as pure virtual to make sure all the 
    sub-classes implement them.
  */  

  virtual String *val_str(String*) = 0;
  virtual my_decimal *val_decimal(my_decimal *) = 0;
  virtual double val_real() = 0;
  virtual longlong val_int() = 0;
  virtual int save_in_field(Field *field, bool no_conversions) = 0;
};

/**
 Implementation of a string cache.
 
 Uses Item::str_value for storage
*/ 
class Item_copy_string : public Item_copy
{
public:
  Item_copy_string (Item *item) : Item_copy(item) {}

  String *val_str(String*);
  my_decimal *val_decimal(my_decimal *);
  double val_real();
  longlong val_int();
  void copy();
  int save_in_field(Field *field, bool no_conversions);
};


class Item_copy_int : public Item_copy
{
protected:  
  longlong cached_value; 
public:
  Item_copy_int (Item *i) : Item_copy(i) {}
  int save_in_field(Field *field, bool no_conversions);

  virtual String *val_str(String*);
  virtual my_decimal *val_decimal(my_decimal *);
  virtual double val_real()
2914
  {
2915
    return null_value ? 0.0 : (double) cached_value;
2916
  }
2917 2918 2919 2920 2921 2922 2923 2924 2925 2926 2927 2928
  virtual longlong val_int()
  {
    return null_value ? LL(0) : cached_value;
  }
  virtual void copy();
};


class Item_copy_uint : public Item_copy_int
{
public:
  Item_copy_uint (Item *item) : Item_copy_int(item) 
unknown's avatar
unknown committed
2929
  {
2930
    unsigned_flag= 1;
2931
  }
2932 2933 2934 2935 2936 2937 2938 2939 2940 2941 2942 2943 2944 2945 2946 2947 2948

  String *val_str(String*);
  double val_real()
  {
    return null_value ? 0.0 : (double) (ulonglong) cached_value;
  }
};


class Item_copy_float : public Item_copy
{
protected:  
  double cached_value; 
public:
  Item_copy_float (Item *i) : Item_copy(i) {}
  int save_in_field(Field *field, bool no_conversions);

unknown's avatar
unknown committed
2949
  String *val_str(String*);
unknown's avatar
unknown committed
2950
  my_decimal *val_decimal(my_decimal *);
2951
  double val_real()
2952
  {
2953
    return null_value ? 0.0 : cached_value;
2954
  }
2955 2956 2957 2958 2959 2960 2961 2962 2963 2964 2965 2966 2967 2968 2969 2970 2971 2972 2973 2974 2975 2976 2977 2978 2979 2980 2981 2982
  longlong val_int()
  {
    return (longlong) rint(val_real());
  }
  void copy()
  {
    cached_value= item->val_real();
    null_value= item->null_value;
  }
};


class Item_copy_decimal : public Item_copy
{
protected:  
  my_decimal cached_value;
public:
  Item_copy_decimal (Item *i) : Item_copy(i) {}
  int save_in_field(Field *field, bool no_conversions);

  String *val_str(String*);
  my_decimal *val_decimal(my_decimal *) 
  { 
    return null_value ? NULL: &cached_value; 
  }
  double val_real();
  longlong val_int();
  void copy();
unknown's avatar
unknown committed
2983 2984 2985
};


unknown's avatar
unknown committed
2986
class Cached_item :public Sql_alloc
unknown's avatar
unknown committed
2987 2988 2989
{
public:
  my_bool null_value;
unknown's avatar
unknown committed
2990
  Cached_item() :null_value(0) {}
unknown's avatar
unknown committed
2991
  virtual bool cmp(void)=0;
unknown's avatar
unknown committed
2992
  virtual ~Cached_item(); /*line -e1509 */
unknown's avatar
unknown committed
2993 2994
};

unknown's avatar
unknown committed
2995
class Cached_item_str :public Cached_item
unknown's avatar
unknown committed
2996 2997
{
  Item *item;
2998
  uint32 value_max_length;
unknown's avatar
unknown committed
2999 3000
  String value,tmp_value;
public:
unknown's avatar
unknown committed
3001
  Cached_item_str(THD *thd, Item *arg);
unknown's avatar
unknown committed
3002
  bool cmp(void);
unknown's avatar
unknown committed
3003
  ~Cached_item_str();                           // Deallocate String:s
unknown's avatar
unknown committed
3004 3005 3006
};


unknown's avatar
unknown committed
3007
class Cached_item_real :public Cached_item
unknown's avatar
unknown committed
3008 3009 3010 3011
{
  Item *item;
  double value;
public:
unknown's avatar
unknown committed
3012
  Cached_item_real(Item *item_par) :item(item_par),value(0.0) {}
unknown's avatar
unknown committed
3013 3014 3015
  bool cmp(void);
};

unknown's avatar
unknown committed
3016
class Cached_item_int :public Cached_item
unknown's avatar
unknown committed
3017 3018 3019 3020
{
  Item *item;
  longlong value;
public:
unknown's avatar
unknown committed
3021
  Cached_item_int(Item *item_par) :item(item_par),value(0) {}
unknown's avatar
unknown committed
3022 3023 3024 3025
  bool cmp(void);
};


unknown's avatar
unknown committed
3026
class Cached_item_decimal :public Cached_item
unknown's avatar
unknown committed
3027 3028 3029 3030
{
  Item *item;
  my_decimal value;
public:
unknown's avatar
unknown committed
3031
  Cached_item_decimal(Item *item_par);
unknown's avatar
unknown committed
3032 3033 3034
  bool cmp(void);
};

unknown's avatar
unknown committed
3035
class Cached_item_field :public Cached_item
unknown's avatar
unknown committed
3036
{
3037
  uchar *buff;
unknown's avatar
unknown committed
3038 3039 3040 3041
  Field *field;
  uint length;

public:
unknown's avatar
unknown committed
3042
  Cached_item_field(Item_field *item)
unknown's avatar
unknown committed
3043
  {
unknown's avatar
unknown committed
3044
    field= item->field;
3045
    buff= (uchar*) sql_calloc(length=field->pack_length());
unknown's avatar
unknown committed
3046 3047 3048 3049
  }
  bool cmp(void);
};

unknown's avatar
SCRUM  
unknown committed
3050 3051 3052 3053
class Item_default_value : public Item_field
{
public:
  Item *arg;
3054 3055 3056 3057 3058 3059 3060 3061
  Item_default_value(Name_resolution_context *context_arg)
    :Item_field(context_arg, (const char *)NULL, (const char *)NULL,
               (const char *)NULL),
     arg(NULL) {}
  Item_default_value(Name_resolution_context *context_arg, Item *a)
    :Item_field(context_arg, (const char *)NULL, (const char *)NULL,
                (const char *)NULL),
     arg(a) {}
unknown's avatar
SCRUM  
unknown committed
3062
  enum Type type() const { return DEFAULT_VALUE_ITEM; }
unknown's avatar
SCRUM  
unknown committed
3063
  bool eq(const Item *item, bool binary_cmp) const;
3064
  bool fix_fields(THD *, Item **);
3065
  virtual void print(String *str, enum_query_type query_type);
3066
  int save_in_field(Field *field_arg, bool no_conversions);
unknown's avatar
SCRUM  
unknown committed
3067
  table_map used_tables() const { return (table_map)0L; }
unknown's avatar
unknown committed
3068

3069
  bool walk(Item_processor processor, bool walk_subquery, uchar *args)
unknown's avatar
unknown committed
3070
  {
3071
    return arg->walk(processor, walk_subquery, args) ||
unknown's avatar
unknown committed
3072 3073
      (this->*processor)(args);
  }
3074

3075
  Item *transform(Item_transformer transformer, uchar *args);
unknown's avatar
unknown committed
3076
};
unknown's avatar
unknown committed
3077

3078 3079 3080 3081 3082 3083 3084 3085 3086 3087
/*
  Item_insert_value -- an implementation of VALUES() function.
  You can use the VALUES(col_name) function in the UPDATE clause
  to refer to column values from the INSERT portion of the INSERT
  ... UPDATE statement. In other words, VALUES(col_name) in the
  UPDATE clause refers to the value of col_name that would be
  inserted, had no duplicate-key conflict occurred.
  In all other places this function returns NULL.
*/

unknown's avatar
unknown committed
3088 3089 3090 3091
class Item_insert_value : public Item_field
{
public:
  Item *arg;
3092 3093 3094 3095
  Item_insert_value(Name_resolution_context *context_arg, Item *a)
    :Item_field(context_arg, (const char *)NULL, (const char *)NULL,
               (const char *)NULL),
     arg(a) {}
unknown's avatar
unknown committed
3096
  bool eq(const Item *item, bool binary_cmp) const;
3097
  bool fix_fields(THD *, Item **);
3098
  virtual void print(String *str, enum_query_type query_type);
3099
  int save_in_field(Field *field_arg, bool no_conversions)
unknown's avatar
unknown committed
3100
  {
3101
    return Item_field::save_in_field(field_arg, no_conversions);
unknown's avatar
unknown committed
3102
  }
3103 3104 3105 3106 3107
  /* 
   We use RAND_TABLE_BIT to prevent Item_insert_value from
   being treated as a constant and precalculated before execution
  */
  table_map used_tables() const { return RAND_TABLE_BIT; }
unknown's avatar
unknown committed
3108

3109
  bool walk(Item_processor processor, bool walk_subquery, uchar *args)
unknown's avatar
unknown committed
3110
  {
3111
    return arg->walk(processor, walk_subquery, args) ||
unknown's avatar
unknown committed
3112 3113
	    (this->*processor)(args);
  }
unknown's avatar
unknown committed
3114 3115
};

3116

unknown's avatar
unknown committed
3117 3118
class Table_triggers_list;

3119 3120 3121 3122
/*
  Represents NEW/OLD version of field of row which is
  changed/read in trigger.

unknown's avatar
unknown committed
3123 3124 3125 3126 3127 3128
  Note: For this item main part of actual binding to Field object happens
        not during fix_fields() call (like for Item_field) but right after
        parsing of trigger definition, when table is opened, with special
        setup_field() call. On fix_fields() stage we simply choose one of
        two Field instances representing either OLD or NEW version of this
        field.
3129
*/
3130 3131
class Item_trigger_field : public Item_field,
                           private Settable_routine_parameter
3132 3133 3134 3135 3136
{
public:
  /* Is this item represents row from NEW or OLD row ? */
  enum row_version_type {OLD_ROW, NEW_ROW};
  row_version_type row_version;
3137 3138
  /* Next in list of all Item_trigger_field's in trigger */
  Item_trigger_field *next_trg_field;
unknown's avatar
unknown committed
3139 3140 3141 3142
  /* Index of the field in the TABLE::field array */
  uint field_idx;
  /* Pointer to Table_trigger_list object for table of this trigger */
  Table_triggers_list *triggers;
3143

3144 3145
  Item_trigger_field(Name_resolution_context *context_arg,
                     row_version_type row_ver_arg,
unknown's avatar
unknown committed
3146
                     const char *field_name_arg,
3147
                     ulong priv, const bool ro)
3148 3149
    :Item_field(context_arg,
               (const char *)NULL, (const char *)NULL, field_name_arg),
3150 3151
     row_version(row_ver_arg), field_idx((uint)-1), original_privilege(priv),
     want_privilege(priv), table_grants(NULL), read_only (ro)
3152
  {}
unknown's avatar
unknown committed
3153
  void setup_field(THD *thd, TABLE *table, GRANT_INFO *table_grant_info);
3154 3155
  enum Type type() const { return TRIGGER_FIELD_ITEM; }
  bool eq(const Item *item, bool binary_cmp) const;
3156
  bool fix_fields(THD *, Item **);
3157
  virtual void print(String *str, enum_query_type query_type);
3158
  table_map used_tables() const { return (table_map)0L; }
3159 3160 3161
  Field *get_tmp_table_field() { return 0; }
  Item *copy_or_same(THD *thd) { return this; }
  Item *get_tmp_table_item(THD *thd) { return copy_or_same(thd); }
3162
  void cleanup();
unknown's avatar
unknown committed
3163 3164

private:
3165
  void set_required_privilege(bool rw);
3166
  bool set_value(THD *thd, sp_rcontext *ctx, Item **it);
3167 3168 3169 3170 3171 3172 3173

public:
  Settable_routine_parameter *get_settable_routine_parameter()
  {
    return (read_only ? 0 : this);
  }

3174
  bool set_value(THD *thd, Item **it)
3175 3176 3177 3178 3179 3180 3181 3182 3183 3184 3185 3186 3187 3188 3189 3190 3191
  {
    return set_value(thd, NULL, it);
  }

private:
  /*
    'want_privilege' holds privileges required to perform operation on
    this trigger field (SELECT_ACL if we are going to read it and
    UPDATE_ACL if we are going to update it).  It is initialized at
    parse time but can be updated later if this trigger field is used
    as OUT or INOUT parameter of stored routine (in this case
    set_required_privilege() is called to appropriately update
    want_privilege and cleanup() is responsible for restoring of
    original want_privilege once parameter's value is updated).
  */
  ulong original_privilege;
  ulong want_privilege;
unknown's avatar
unknown committed
3192
  GRANT_INFO *table_grants;
3193 3194 3195 3196 3197
  /*
    Trigger field is read-only unless it belongs to the NEW row in a
    BEFORE INSERT of BEFORE UPDATE trigger.
  */
  bool read_only;
3198 3199 3200
};


3201
class Item_cache: public Item_basic_constant
3202
{
unknown's avatar
unknown committed
3203 3204
protected:
  Item *example;
3205
  table_map used_table_map;
3206 3207 3208 3209 3210 3211 3212
  /*
    Field that this object will get value from. This is set/used by 
    index-based subquery engines to detect and remove the equality injected 
    by IN->EXISTS transformation.
    For all other uses of Item_cache, cached_field doesn't matter.
  */  
  Field *cached_field;
3213
  enum enum_field_types cached_field_type;
3214 3215 3216 3217 3218 3219 3220 3221
  /*
    TRUE <=> cache holds value of the last stored item (i.e actual value).
    store() stores item to be cached and sets this flag to FALSE.
    On the first call of val_xxx function if this flag is set to FALSE the 
    cache_value() will be called to actually cache value of saved item.
    cache_value() will set this flag to TRUE.
  */
  bool value_cached;
3222
public:
3223
  Item_cache():
3224 3225
    example(0), used_table_map(0), cached_field(0),
    cached_field_type(MYSQL_TYPE_STRING),
3226
    value_cached(0)
3227 3228 3229 3230 3231
  {
    fixed= 1; 
    null_value= 1;
  }
  Item_cache(enum_field_types field_type_arg):
3232 3233
    example(0), used_table_map(0), cached_field(0),
    cached_field_type(field_type_arg),
3234
    value_cached(0)
3235 3236 3237 3238
  {
    fixed= 1;
    null_value= 1;
  }
3239 3240 3241

  void set_used_tables(table_map map) { used_table_map= map; }

unknown's avatar
unknown committed
3242
  virtual bool allocate(uint i) { return 0; }
3243
  virtual bool setup(Item *item)
3244
  {
3245 3246 3247 3248
    example= item;
    max_length= item->max_length;
    decimals= item->decimals;
    collation.set(item->collation);
3249
    unsigned_flag= item->unsigned_flag;
3250 3251
    if (item->type() == FIELD_ITEM)
      cached_field= ((Item_field *)item)->field;
3252 3253
    return 0;
  };
3254
  enum Type type() const { return CACHE_ITEM; }
3255
  enum_field_types field_type() const { return cached_field_type; }
3256
  static Item_cache* get_cache(const Item *item);
3257
  static Item_cache* get_cache(const Item* item, const Item_result type);
3258
  table_map used_tables() const { return used_table_map; }
3259
  virtual void keep_array() {}
3260
  virtual void print(String *str, enum_query_type query_type);
3261 3262 3263 3264 3265 3266 3267 3268
  bool eq_def(Field *field) 
  { 
    return cached_field ? cached_field->eq_def (field) : FALSE;
  }
  bool eq(const Item *item, bool binary_cmp) const
  {
    return this == item;
  }
3269 3270 3271 3272 3273 3274 3275 3276 3277
  /**
     Check if saved item has a non-NULL value.
     Will cache value of saved item if not already done. 
     @return TRUE if cached value is non-NULL.
   */
  bool has_value()
  {
    return (value_cached || cache_value()) && !null_value;
  }
3278
  virtual void store(Item *item);
3279
  virtual bool cache_value()= 0;
3280 3281
  bool basic_const_item() const
  { return test(example && example->basic_const_item());}
3282
  virtual void clear() { null_value= TRUE; value_cached= FALSE; }
3283 3284 3285 3286 3287 3288
  Item_result result_type() const
  {
    if (!example)
      return INT_RESULT;
    return Field::result_merge_type(example->field_type());
  }
3289 3290
};

unknown's avatar
unknown committed
3291

3292 3293
class Item_cache_int: public Item_cache
{
unknown's avatar
unknown committed
3294
protected:
3295 3296
  longlong value;
public:
3297 3298
  Item_cache_int(): Item_cache(),
    value(0) {}
3299 3300
  Item_cache_int(enum_field_types field_type_arg):
    Item_cache(field_type_arg), value(0) {}
unknown's avatar
unknown committed
3301

3302
  virtual void store(Item *item){ Item_cache::store(item); }
3303
  void store(Item *item, longlong val_arg);
3304 3305
  double val_real();
  longlong val_int();
unknown's avatar
unknown committed
3306 3307
  String* val_str(String *str);
  my_decimal *val_decimal(my_decimal *);
3308
  enum Item_result result_type() const { return INT_RESULT; }
3309
  bool result_as_longlong() { return TRUE; }
3310
  bool cache_value();
3311 3312
};

unknown's avatar
unknown committed
3313

3314 3315 3316 3317
class Item_cache_real: public Item_cache
{
  double value;
public:
3318 3319
  Item_cache_real(): Item_cache(),
    value(0) {}
3320

3321
  double val_real();
unknown's avatar
unknown committed
3322 3323 3324
  longlong val_int();
  String* val_str(String *str);
  my_decimal *val_decimal(my_decimal *);
3325
  enum Item_result result_type() const { return REAL_RESULT; }
3326
  bool cache_value();
3327 3328
};

unknown's avatar
unknown committed
3329 3330 3331 3332 3333 3334 3335 3336 3337 3338 3339 3340 3341

class Item_cache_decimal: public Item_cache
{
protected:
  my_decimal decimal_value;
public:
  Item_cache_decimal(): Item_cache() {}

  double val_real();
  longlong val_int();
  String* val_str(String *str);
  my_decimal *val_decimal(my_decimal *);
  enum Item_result result_type() const { return DECIMAL_RESULT; }
3342
  bool cache_value();
unknown's avatar
unknown committed
3343 3344 3345
};


3346 3347
class Item_cache_str: public Item_cache
{
unknown's avatar
unknown committed
3348
  char buffer[STRING_BUFFER_USUAL_SIZE];
3349
  String *value, value_buff;
3350 3351
  bool is_varbinary;
  
3352
public:
3353
  Item_cache_str(const Item *item) :
3354
    Item_cache(item->field_type()), value(0),
3355
    is_varbinary(item->type() == FIELD_ITEM &&
3356
                 cached_field_type == MYSQL_TYPE_VARCHAR &&
3357
                 !((const Item_field *) item)->field->has_charset())
3358 3359 3360
  {
    collation.set(const_cast<DTCollation&>(item->collation));
  }
3361
  double val_real();
3362
  longlong val_int();
3363
  String* val_str(String *);
unknown's avatar
unknown committed
3364
  my_decimal *val_decimal(my_decimal *);
3365 3366
  enum Item_result result_type() const { return STRING_RESULT; }
  CHARSET_INFO *charset() const { return value->charset(); };
3367
  int save_in_field(Field *field, bool no_conversions);
3368
  bool cache_value();
3369 3370
};

unknown's avatar
unknown committed
3371 3372 3373
class Item_cache_row: public Item_cache
{
  Item_cache  **values;
unknown's avatar
unknown committed
3374
  uint item_count;
3375
  bool save_array;
unknown's avatar
unknown committed
3376
public:
3377
  Item_cache_row()
3378 3379
    :Item_cache(), values(0), item_count(2),
    save_array(0) {}
unknown's avatar
unknown committed
3380 3381 3382 3383 3384 3385 3386 3387 3388 3389 3390 3391 3392 3393 3394 3395 3396
  
  /*
    'allocate' used only in row transformer, to preallocate space for row 
    cache.
  */
  bool allocate(uint num);
  /*
    'setup' is needed only by row => it not called by simple row subselect
    (only by IN subselect (in subselect optimizer))
  */
  bool setup(Item *item);
  void store(Item *item);
  void illegal_method_call(const char *);
  void make_field(Send_field *)
  {
    illegal_method_call((const char*)"make_field");
  };
3397
  double val_real()
unknown's avatar
unknown committed
3398 3399 3400 3401 3402 3403 3404 3405 3406 3407 3408 3409 3410 3411
  {
    illegal_method_call((const char*)"val");
    return 0;
  };
  longlong val_int()
  {
    illegal_method_call((const char*)"val_int");
    return 0;
  };
  String *val_str(String *)
  {
    illegal_method_call((const char*)"val_str");
    return 0;
  };
unknown's avatar
unknown committed
3412 3413 3414 3415 3416 3417
  my_decimal *val_decimal(my_decimal *val)
  {
    illegal_method_call((const char*)"val_decimal");
    return 0;
  };

unknown's avatar
unknown committed
3418 3419
  enum Item_result result_type() const { return ROW_RESULT; }
  
unknown's avatar
unknown committed
3420
  uint cols() { return item_count; }
3421 3422
  Item *element_index(uint i) { return values[i]; }
  Item **addr(uint i) { return (Item **) (values + i); }
unknown's avatar
unknown committed
3423 3424 3425
  bool check_cols(uint c);
  bool null_inside();
  void bring_value();
3426
  void keep_array() { save_array= 1; }
unknown's avatar
unknown committed
3427 3428
  void cleanup()
  {
unknown's avatar
unknown committed
3429
    DBUG_ENTER("Item_cache_row::cleanup");
unknown's avatar
unknown committed
3430
    Item_cache::cleanup();
3431 3432 3433 3434
    if (save_array)
      bzero(values, item_count*sizeof(Item**));
    else
      values= 0;
unknown's avatar
unknown committed
3435
    DBUG_VOID_RETURN;
unknown's avatar
unknown committed
3436
  }
3437
  bool cache_value();
unknown's avatar
unknown committed
3438 3439
};

3440

3441 3442 3443 3444 3445 3446 3447 3448 3449 3450 3451 3452 3453 3454
class Item_cache_datetime: public Item_cache
{
protected:
  String str_value;
  ulonglong int_value;
  bool str_value_cached;
public:
  Item_cache_datetime(enum_field_types field_type_arg):
    Item_cache(field_type_arg), int_value(0), str_value_cached(0)
  {
    cmp_context= STRING_RESULT;
  }

  void store(Item *item, longlong val_arg);
3455
  void store(Item *item);
3456 3457 3458 3459 3460 3461 3462 3463 3464 3465 3466 3467 3468
  double val_real();
  longlong val_int();
  String* val_str(String *str);
  my_decimal *val_decimal(my_decimal *);
  enum Item_result result_type() const { return STRING_RESULT; }
  bool result_as_longlong() { return TRUE; }
  /*
    In order to avoid INT <-> STRING conversion of a DATETIME value
    two cache_value functions are introduced. One (cache_value) caches STRING
    value, another (cache_value_int) - INT value. Thus this cache item
    completely relies on the ability of the underlying item to do the
    correct conversion.
  */
Evgeny Potemkin's avatar
Evgeny Potemkin committed
3469
  bool cache_value_int();
3470
  bool cache_value();
3471
  void clear() { Item_cache::clear(); str_value_cached= FALSE; }
3472 3473 3474
};


3475
/*
3476 3477 3478 3479 3480
  Item_type_holder used to store type. name, length of Item for UNIONS &
  derived tables.

  Item_type_holder do not need cleanup() because its time of live limited by
  single SP/PS execution.
3481 3482 3483 3484
*/
class Item_type_holder: public Item
{
protected:
3485 3486
  TYPELIB *enum_set_typelib;
  enum_field_types fld_type;
3487
  Field::geometry_type geometry_type;
3488 3489

  void get_full_info(Item *item);
unknown's avatar
unknown committed
3490 3491 3492

  /* It is used to count decimal precision in join_types */
  int prev_decimal_int_part;
3493
public:
3494
  Item_type_holder(THD*, Item*);
3495

3496
  Item_result result_type() const;
3497
  enum_field_types field_type() const { return fld_type; };
3498
  enum Type type() const { return TYPE_HOLDER; }
3499
  double val_real();
3500
  longlong val_int();
unknown's avatar
unknown committed
3501
  my_decimal *val_decimal(my_decimal *);
3502
  String *val_str(String*);
3503 3504 3505 3506
  bool join_types(THD *thd, Item *);
  Field *make_field_by_type(TABLE *table);
  static uint32 display_length(Item *item);
  static enum_field_types get_real_type(Item *);
3507
  Field::geometry_type get_geometry_type() const { return geometry_type; };
3508 3509
};

3510

3511 3512 3513
class st_select_lex;
void mark_select_range_as_dependent(THD *thd,
                                    st_select_lex *last_select,
unknown's avatar
unknown committed
3514
                                    st_select_lex *current_sel,
3515 3516
                                    Field *found_field, Item *found_item,
                                    Item_ident *resolved_item);
3517

unknown's avatar
unknown committed
3518
extern Cached_item *new_Cached_item(THD *thd, Item *item);
unknown's avatar
unknown committed
3519
extern Item_result item_cmp_type(Item_result a,Item_result b);
3520
extern void resolve_const_item(THD *thd, Item **ref, Item *cmp_item);
3521
extern int stored_field_cmp_to_item(THD *thd, Field *field, Item *item);
3522 3523 3524

extern const String my_null_string;

3525
#endif /* ITEM_INCLUDED */