2003-09-23 00:38:01 +02:00
|
|
|
/* Copyright (C) 2000-2003 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
|
2001-12-06 13:10:51 +01:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
2001-12-06 13:10:51 +01:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
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.
|
2001-12-06 13:10:51 +01:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
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 */
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __GNUC__
|
|
|
|
#pragma interface /* gcc class implementation */
|
|
|
|
#endif
|
|
|
|
|
2002-12-11 08:17:51 +01:00
|
|
|
class Protocol;
|
2000-07-31 21:29:14 +02:00
|
|
|
struct st_table_list;
|
2002-11-13 23:26:18 +01:00
|
|
|
void item_init(void); /* Init item functions */
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2003-06-24 12:11:07 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
"Declared Type Collation"
|
|
|
|
A combination of collation and its deriviation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
enum Derivation
|
|
|
|
{
|
|
|
|
DERIVATION_COERCIBLE= 3,
|
|
|
|
DERIVATION_IMPLICIT= 2,
|
|
|
|
DERIVATION_NONE= 1,
|
|
|
|
DERIVATION_EXPLICIT= 0
|
|
|
|
};
|
|
|
|
|
|
|
|
class DTCollation {
|
|
|
|
public:
|
|
|
|
CHARSET_INFO *collation;
|
|
|
|
enum Derivation derivation;
|
|
|
|
|
|
|
|
DTCollation()
|
|
|
|
{
|
|
|
|
collation= &my_charset_bin;
|
|
|
|
derivation= DERIVATION_NONE;
|
|
|
|
}
|
|
|
|
DTCollation(CHARSET_INFO *collation_arg, Derivation derivation_arg)
|
|
|
|
{
|
|
|
|
collation= collation_arg;
|
|
|
|
derivation= derivation_arg;
|
|
|
|
}
|
2003-06-24 14:12:07 +02:00
|
|
|
void set(DTCollation &dt)
|
2003-06-24 12:11:07 +02:00
|
|
|
{
|
2003-06-24 14:12:07 +02:00
|
|
|
collation= dt.collation;
|
|
|
|
derivation= dt.derivation;
|
2003-06-24 12:11:07 +02:00
|
|
|
}
|
|
|
|
void set(CHARSET_INFO *collation_arg, Derivation derivation_arg)
|
|
|
|
{
|
|
|
|
collation= collation_arg;
|
|
|
|
derivation= derivation_arg;
|
|
|
|
}
|
|
|
|
void set(CHARSET_INFO *collation_arg)
|
|
|
|
{ collation= collation_arg; }
|
|
|
|
void set(Derivation derivation_arg)
|
|
|
|
{ derivation= derivation_arg; }
|
2003-06-24 14:12:07 +02:00
|
|
|
bool aggregate(DTCollation &dt);
|
|
|
|
bool set(DTCollation &dt1, DTCollation &dt2)
|
|
|
|
{ set(dt1); return aggregate(dt2); }
|
2003-06-24 12:11:07 +02:00
|
|
|
const char *derivation_name() const
|
|
|
|
{
|
|
|
|
switch(derivation)
|
|
|
|
{
|
|
|
|
case DERIVATION_COERCIBLE: return "COERCIBLE";
|
|
|
|
case DERIVATION_IMPLICIT: return "IMPLICIT";
|
|
|
|
case DERIVATION_EXPLICIT: return "EXPLICIT";
|
|
|
|
case DERIVATION_NONE: return "NONE";
|
|
|
|
default: return "UNKNOWN";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2003-07-02 12:12:18 +02:00
|
|
|
typedef bool (Item::*Item_processor)(byte *arg);
|
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
class Item {
|
2002-11-13 23:26:18 +01:00
|
|
|
Item(const Item &); /* Prevent use of these */
|
2000-07-31 21:29:14 +02:00
|
|
|
void operator=(Item &);
|
|
|
|
public:
|
2000-08-23 14:02:27 +02:00
|
|
|
static void *operator new(size_t size) {return (void*) sql_alloc((uint) size); }
|
2003-06-04 17:28:51 +02:00
|
|
|
static void *operator new(size_t size, MEM_ROOT *mem_root)
|
|
|
|
{ return (void*) alloc_root(mem_root, (uint) size); }
|
2000-07-31 21:29:14 +02:00
|
|
|
static void operator delete(void *ptr,size_t size) {} /*lint -e715 */
|
|
|
|
|
2002-12-19 06:38:32 +01:00
|
|
|
enum Type {FIELD_ITEM, FUNC_ITEM, SUM_FUNC_ITEM, STRING_ITEM,
|
|
|
|
INT_ITEM, REAL_ITEM, NULL_ITEM, VARBIN_ITEM,
|
2003-01-22 17:08:12 +01:00
|
|
|
COPY_STR_ITEM, FIELD_AVG_ITEM, DEFAULT_VALUE_ITEM,
|
2003-05-03 01:16:56 +02:00
|
|
|
PROC_ITEM,COND_ITEM, REF_ITEM, FIELD_STD_ITEM,
|
|
|
|
FIELD_VARIANCE_ITEM, INSERT_VALUE_ITEM,
|
2003-11-23 01:01:15 +01:00
|
|
|
SUBSELECT_ITEM, ROW_ITEM, CACHE_ITEM, TYPE_HOLDER};
|
2003-01-21 17:20:46 +01:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
enum cond_result { COND_UNDEF,COND_OK,COND_TRUE,COND_FALSE };
|
2003-05-20 13:36:59 +02:00
|
|
|
|
2004-03-25 21:11:22 +01:00
|
|
|
/*
|
|
|
|
str_values's main purpose is to be used to cache the value in
|
|
|
|
save_in_field
|
|
|
|
*/
|
|
|
|
String str_value;
|
2000-07-31 21:29:14 +02:00
|
|
|
my_string name; /* Name from select */
|
|
|
|
Item *next;
|
|
|
|
uint32 max_length;
|
|
|
|
uint8 marker,decimals;
|
|
|
|
my_bool maybe_null; /* If item may be null */
|
|
|
|
my_bool null_value; /* if item is null */
|
2001-09-27 20:45:48 +02:00
|
|
|
my_bool unsigned_flag;
|
2000-07-31 21:29:14 +02:00
|
|
|
my_bool with_sum_func;
|
2002-11-21 10:01:33 +01:00
|
|
|
my_bool fixed; /* If item fixed with fix_fields */
|
2003-06-24 12:11:07 +02:00
|
|
|
DTCollation collation;
|
2003-10-20 10:24:18 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
// alloc & destruct is done as start of select using sql_alloc
|
|
|
|
Item();
|
2003-01-30 17:07:39 +01:00
|
|
|
/*
|
|
|
|
Constructor used by Item_field, Item_ref & agregate (sum) functions.
|
|
|
|
Used for duplicating lists in processing queries with temporary
|
|
|
|
tables
|
2003-09-02 18:56:55 +02:00
|
|
|
Also it used for Item_cond_and/Item_cond_or for creating
|
|
|
|
top AND/OR ctructure of WHERE clause to protect it of
|
|
|
|
optimisation changes in prepared statements
|
2003-01-30 17:07:39 +01:00
|
|
|
*/
|
2004-01-19 16:53:25 +01:00
|
|
|
Item(THD *thd, Item *item);
|
2004-01-20 17:55:47 +01:00
|
|
|
virtual ~Item() { name=0; } /*lint -e1509 */
|
2003-03-17 18:56:34 +01:00
|
|
|
void set_name(const char *str,uint length, CHARSET_INFO *cs);
|
2000-07-31 21:29:14 +02:00
|
|
|
void init_make_field(Send_field *tmp_field,enum enum_field_types type);
|
2004-02-08 19:14:13 +01:00
|
|
|
virtual void cleanup()
|
|
|
|
{
|
|
|
|
DBUG_ENTER("Item::cleanup");
|
|
|
|
DBUG_PRINT("info", ("Type: %d", (int)type()));
|
|
|
|
fixed=0;
|
|
|
|
DBUG_VOID_RETURN;
|
|
|
|
}
|
2002-12-11 08:17:51 +01:00
|
|
|
virtual void make_field(Send_field *field);
|
2002-07-01 13:14:51 +02:00
|
|
|
virtual bool fix_fields(THD *, struct st_table_list *, Item **);
|
2004-03-20 12:36:26 +01:00
|
|
|
/*
|
2004-03-25 21:11:22 +01:00
|
|
|
should be used in case where we are sure that we do not need
|
2004-03-20 12:36:26 +01:00
|
|
|
complete fix_fields() procedure.
|
|
|
|
*/
|
|
|
|
inline void quick_fix_field() { fixed= 1; }
|
2004-04-12 00:42:39 +02:00
|
|
|
/* Function returns 1 on overflow and -1 on fatal errors */
|
2002-12-05 18:38:42 +01:00
|
|
|
virtual int save_in_field(Field *field, bool no_conversions);
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual void save_org_in_field(Field *field)
|
2002-12-03 12:08:25 +01:00
|
|
|
{ (void) save_in_field(field, 1); }
|
2002-10-16 21:48:51 +02:00
|
|
|
virtual int save_safe_in_field(Field *field)
|
2002-12-03 12:08:25 +01:00
|
|
|
{ return save_in_field(field, 1); }
|
2002-12-11 08:17:51 +01:00
|
|
|
virtual bool send(Protocol *protocol, String *str);
|
2002-03-22 13:03:42 +01:00
|
|
|
virtual bool eq(const Item *, bool binary_cmp) const;
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual Item_result result_type () const { return REAL_RESULT; }
|
2002-12-11 08:17:51 +01:00
|
|
|
virtual enum_field_types field_type() const;
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual enum Type type() const =0;
|
|
|
|
virtual double val()=0;
|
|
|
|
virtual longlong val_int()=0;
|
|
|
|
virtual String *val_str(String*)=0;
|
2003-08-29 15:24:03 +02:00
|
|
|
virtual Field *get_tmp_table_field() { return 0; }
|
2003-01-25 01:25:52 +01:00
|
|
|
virtual Field *tmp_table_field(TABLE *t_arg) { return 0; }
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual const char *full_name() const { return name ? name : "???"; }
|
|
|
|
virtual double val_result() { return val(); }
|
|
|
|
virtual longlong val_int_result() { return val_int(); }
|
|
|
|
virtual String *str_result(String* tmp) { return val_str(tmp); }
|
2003-06-26 04:38:19 +02:00
|
|
|
/* bit map of tables used by item */
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual table_map used_tables() const { return (table_map) 0L; }
|
2003-06-26 04:38:19 +02:00
|
|
|
/*
|
|
|
|
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
|
|
|
|
a constant expression
|
|
|
|
*/
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual bool basic_const_item() const { return 0; }
|
|
|
|
virtual Item *new_item() { return 0; } /* Only for const items */
|
|
|
|
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;}
|
2003-11-22 22:48:18 +01:00
|
|
|
/*
|
|
|
|
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.
|
|
|
|
*/
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual bool const_item() const { return used_tables() == 0; }
|
2003-11-22 22:48:18 +01:00
|
|
|
/*
|
|
|
|
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; }
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual void print(String *str_arg) { str_arg->append(full_name()); }
|
2003-10-16 14:54:47 +02:00
|
|
|
void print_item_w_name(String *);
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual void update_used_tables() {}
|
2003-01-25 01:25:52 +01:00
|
|
|
virtual void split_sum_func(Item **ref_pointer_array, List<Item> &fields) {}
|
2003-11-03 13:01:59 +01:00
|
|
|
virtual bool get_date(TIME *ltime,uint fuzzydate);
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual bool get_time(TIME *ltime);
|
2003-11-03 13:01:59 +01:00
|
|
|
virtual bool get_date_result(TIME *ltime,uint fuzzydate)
|
2003-03-11 21:20:53 +01:00
|
|
|
{ return get_date(ltime,fuzzydate); }
|
2003-05-14 20:51:33 +02:00
|
|
|
virtual bool is_null() { return 0; }
|
2002-11-11 14:57:35 +01:00
|
|
|
virtual void top_level_item() {}
|
2003-01-28 07:38:28 +01:00
|
|
|
virtual void set_result_field(Field *field) {}
|
|
|
|
virtual bool is_result_field() { return 0; }
|
|
|
|
virtual void save_in_result_field(bool no_conversions) {}
|
2003-02-03 19:20:32 +01:00
|
|
|
virtual void no_rows_in_result() {}
|
2003-01-30 17:07:39 +01:00
|
|
|
virtual Item *copy_or_same(THD *thd) { return this; }
|
2003-09-02 18:56:55 +02:00
|
|
|
virtual Item *copy_andor_structure(THD *thd) { return this; }
|
2003-02-10 16:59:16 +01:00
|
|
|
virtual Item *real_item() { return this; }
|
2003-01-30 17:07:39 +01:00
|
|
|
virtual Item *get_tmp_table_item(THD *thd) { return copy_or_same(thd); }
|
2002-11-25 16:33:51 +01:00
|
|
|
|
2003-03-03 07:53:08 +01:00
|
|
|
CHARSET_INFO *default_charset() const;
|
2004-02-02 14:50:14 +01:00
|
|
|
virtual CHARSET_INFO *compare_collation() { return NULL; }
|
2003-07-02 12:12:18 +02:00
|
|
|
|
|
|
|
virtual bool walk(Item_processor processor, byte *arg)
|
|
|
|
{
|
|
|
|
return (this->*processor)(arg);
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual bool remove_dependence_processor(byte * arg) { return 0; }
|
2003-08-23 12:29:38 +02:00
|
|
|
virtual bool remove_fixed(byte * arg) { fixed= 0; return 0; }
|
2003-06-24 10:37:11 +02:00
|
|
|
|
2002-11-15 19:32:09 +01:00
|
|
|
// Row emulation
|
|
|
|
virtual uint cols() { return 1; }
|
|
|
|
virtual Item* el(uint i) { return this; }
|
2002-12-04 10:01:48 +01:00
|
|
|
virtual Item** addr(uint i) { return 0; }
|
2002-11-15 19:32:09 +01:00
|
|
|
virtual bool check_cols(uint c);
|
2002-12-10 17:10:00 +01:00
|
|
|
// It is not row => null inside is impossible
|
2002-12-19 06:38:33 +01:00
|
|
|
virtual bool null_inside() { return 0; }
|
|
|
|
// used in row subselects to get value of elements
|
|
|
|
virtual void bring_value() {}
|
2003-08-28 01:11:54 +02:00
|
|
|
|
|
|
|
Field *tmp_table_field_from_field_type(TABLE *table);
|
2003-10-31 10:02:16 +01:00
|
|
|
|
|
|
|
/* Used in sql_select.cc:eliminate_not_funcs() */
|
2004-03-17 13:26:26 +01:00
|
|
|
virtual Item *neg_transformer(THD *thd) { return NULL; }
|
2004-01-20 17:55:47 +01:00
|
|
|
void delete_self()
|
|
|
|
{
|
|
|
|
cleanup();
|
|
|
|
delete this;
|
|
|
|
}
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2004-03-18 17:27:03 +01:00
|
|
|
class Item_num: public Item
|
|
|
|
{
|
|
|
|
public:
|
2004-03-25 21:11:22 +01:00
|
|
|
virtual Item_num *neg()= 0;
|
2004-03-18 17:27:03 +01:00
|
|
|
};
|
|
|
|
|
2004-03-31 19:25:55 +02:00
|
|
|
#define NO_CACHED_FIELD_INDEX ((uint)(-1))
|
2004-03-18 17:27:03 +01:00
|
|
|
|
2002-07-01 13:14:51 +02:00
|
|
|
class st_select_lex;
|
2000-07-31 21:29:14 +02:00
|
|
|
class Item_ident :public Item
|
|
|
|
{
|
2004-03-31 19:25:55 +02:00
|
|
|
/*
|
|
|
|
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;
|
2004-03-17 13:26:26 +01:00
|
|
|
Item **changed_during_fix_field;
|
2000-07-31 21:29:14 +02:00
|
|
|
public:
|
|
|
|
const char *db_name;
|
|
|
|
const char *table_name;
|
|
|
|
const char *field_name;
|
2004-03-28 01:11:54 +01:00
|
|
|
/*
|
|
|
|
Cached value of index for this field in table->field array, used by prep.
|
2004-03-31 19:25:55 +02:00
|
|
|
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.
|
2004-03-28 01:11:54 +01:00
|
|
|
*/
|
2004-03-31 19:25:55 +02:00
|
|
|
TABLE_LIST *cached_table;
|
2002-07-01 13:14:51 +02:00
|
|
|
st_select_lex *depended_from;
|
2000-07-31 21:29:14 +02:00
|
|
|
Item_ident(const char *db_name_par,const char *table_name_par,
|
2003-12-14 05:39:52 +01:00
|
|
|
const char *field_name_par);
|
2004-02-27 19:08:56 +01:00
|
|
|
Item_ident(THD *thd, Item_ident *item);
|
2000-07-31 21:29:14 +02:00
|
|
|
const char *full_name() const;
|
2004-03-17 13:26:26 +01:00
|
|
|
void cleanup();
|
|
|
|
void register_item_tree_changing(Item **ref)
|
|
|
|
{ changed_during_fix_field= ref; }
|
2003-07-02 12:12:18 +02:00
|
|
|
bool remove_dependence_processor(byte * arg);
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
2002-07-23 17:31:22 +02:00
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
class Item_field :public Item_ident
|
|
|
|
{
|
|
|
|
void set_field(Field *field);
|
|
|
|
public:
|
|
|
|
Field *field,*result_field;
|
2004-03-17 13:26:26 +01:00
|
|
|
#ifndef DBUG_OFF
|
|
|
|
bool double_fix;
|
|
|
|
#endif
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
Item_field(const char *db_par,const char *table_name_par,
|
|
|
|
const char *field_name_par)
|
2004-03-17 13:26:26 +01:00
|
|
|
:Item_ident(db_par,table_name_par,field_name_par),
|
|
|
|
field(0), result_field(0)
|
|
|
|
#ifndef DBUG_OFF
|
|
|
|
,double_fix(0)
|
|
|
|
#endif
|
2003-08-05 09:52:37 +02:00
|
|
|
{ collation.set(DERIVATION_IMPLICIT); }
|
2003-01-30 17:07:39 +01:00
|
|
|
// Constructor need to process subselect with temporary tables (see Item)
|
2004-01-19 16:53:25 +01:00
|
|
|
Item_field(THD *thd, Item_field *item);
|
2004-03-31 19:25:55 +02:00
|
|
|
/*
|
|
|
|
Constructor used inside setup_wild(), ensures that field and table
|
|
|
|
names will live as long as Item_field (important in prep. stmt.)
|
|
|
|
*/
|
|
|
|
Item_field(THD *thd, Field *field);
|
2004-03-20 12:36:26 +01:00
|
|
|
Item_field(Field *field);
|
2000-07-31 21:29:14 +02:00
|
|
|
enum Type type() const { return FIELD_ITEM; }
|
2002-03-22 13:03:42 +01:00
|
|
|
bool eq(const Item *item, bool binary_cmp) const;
|
2000-07-31 21:29:14 +02:00
|
|
|
double val();
|
|
|
|
longlong val_int();
|
|
|
|
String *val_str(String*);
|
|
|
|
double val_result();
|
|
|
|
longlong val_int_result();
|
|
|
|
String *str_result(String* tmp);
|
2002-12-11 08:17:51 +01:00
|
|
|
bool send(Protocol *protocol, String *str_arg);
|
2002-07-01 13:14:51 +02:00
|
|
|
bool fix_fields(THD *, struct st_table_list *, Item **);
|
2002-12-11 08:17:51 +01:00
|
|
|
void make_field(Send_field *tmp_field);
|
2002-12-05 18:38:42 +01:00
|
|
|
int save_in_field(Field *field,bool no_conversions);
|
2000-07-31 21:29:14 +02:00
|
|
|
void save_org_in_field(Field *field);
|
|
|
|
table_map used_tables() const;
|
|
|
|
enum Item_result result_type () const
|
|
|
|
{
|
|
|
|
return field->result_type();
|
|
|
|
}
|
2002-12-15 10:14:53 +01:00
|
|
|
enum_field_types field_type() const
|
2002-12-11 08:17:51 +01:00
|
|
|
{
|
|
|
|
return field->type();
|
|
|
|
}
|
2003-08-29 15:24:03 +02:00
|
|
|
Field *get_tmp_table_field() { return result_field; }
|
2003-01-25 01:25:52 +01:00
|
|
|
Field *tmp_table_field(TABLE *t_arg) { return result_field; }
|
2003-11-03 13:01:59 +01:00
|
|
|
bool get_date(TIME *ltime,uint fuzzydate);
|
|
|
|
bool get_date_result(TIME *ltime,uint fuzzydate);
|
2003-03-11 21:20:53 +01:00
|
|
|
bool get_time(TIME *ltime);
|
2001-10-04 01:44:18 +02:00
|
|
|
bool is_null() { return field->is_null(); }
|
2003-01-30 17:07:39 +01:00
|
|
|
Item *get_tmp_table_item(THD *thd);
|
2003-12-30 11:08:19 +01:00
|
|
|
void cleanup();
|
2003-01-05 11:07:24 +01:00
|
|
|
friend class Item_default_value;
|
2003-05-03 01:16:56 +02:00
|
|
|
friend class Item_insert_value;
|
2004-03-20 12:36:26 +01:00
|
|
|
friend class st_select_lex_unit;
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
class Item_null :public Item
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_null(char *name_par=0)
|
2004-03-20 12:36:26 +01:00
|
|
|
{
|
|
|
|
maybe_null= null_value= TRUE;
|
|
|
|
max_length= 0;
|
|
|
|
name= name_par ? name_par : (char*) "NULL";
|
|
|
|
fixed= 1;
|
|
|
|
}
|
2000-07-31 21:29:14 +02:00
|
|
|
enum Type type() const { return NULL_ITEM; }
|
2002-03-22 13:03:42 +01:00
|
|
|
bool eq(const Item *item, bool binary_cmp) const;
|
2000-07-31 21:29:14 +02:00
|
|
|
double val();
|
|
|
|
longlong val_int();
|
|
|
|
String *val_str(String *str);
|
2002-12-05 18:38:42 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions);
|
2002-10-16 18:30:24 +02:00
|
|
|
int save_safe_in_field(Field *field);
|
2002-12-16 15:58:55 +01:00
|
|
|
bool send(Protocol *protocol, String *str);
|
2002-12-11 08:17:51 +01:00
|
|
|
enum Item_result result_type () const { return STRING_RESULT; }
|
|
|
|
enum_field_types field_type() const { return MYSQL_TYPE_NULL; }
|
2004-03-20 12:36:26 +01:00
|
|
|
// to prevent drop fixed flag (no need parent cleanup call)
|
|
|
|
void cleanup() {}
|
2000-07-31 21:29:14 +02:00
|
|
|
bool basic_const_item() const { return 1; }
|
|
|
|
Item *new_item() { return new Item_null(name); }
|
2001-10-04 01:44:18 +02:00
|
|
|
bool is_null() { return 1; }
|
2003-10-30 11:57:26 +01:00
|
|
|
void print(String *str) { str->append("NULL", 4); }
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
2002-06-12 23:13:12 +02:00
|
|
|
class Item_param :public Item
|
|
|
|
{
|
|
|
|
public:
|
2003-11-22 22:48:18 +01:00
|
|
|
bool value_is_set;
|
2002-06-12 23:13:12 +02:00
|
|
|
longlong int_value;
|
|
|
|
double real_value;
|
2003-01-24 07:32:39 +01:00
|
|
|
TIME ltime;
|
2002-06-12 23:13:12 +02:00
|
|
|
enum Item_result item_result_type;
|
|
|
|
enum Type item_type;
|
|
|
|
enum enum_field_types buffer_type;
|
2003-01-24 07:32:39 +01:00
|
|
|
bool item_is_time;
|
2003-04-04 19:33:17 +02:00
|
|
|
bool long_data_supplied;
|
|
|
|
uint pos_in_query;
|
2002-06-12 23:13:12 +02:00
|
|
|
|
2004-03-15 18:20:47 +01:00
|
|
|
Item_param(uint position);
|
2002-06-12 23:13:12 +02:00
|
|
|
enum Type type() const { return item_type; }
|
|
|
|
double val();
|
|
|
|
longlong val_int();
|
|
|
|
String *val_str(String*);
|
2002-12-07 08:39:11 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions);
|
2002-06-12 23:13:12 +02:00
|
|
|
void set_null();
|
|
|
|
void set_int(longlong i);
|
|
|
|
void set_double(double i);
|
2002-11-22 19:04:42 +01:00
|
|
|
void set_value(const char *str, uint length);
|
|
|
|
void set_long_str(const char *str, ulong length);
|
|
|
|
void set_long_binary(const char *str, ulong length);
|
|
|
|
void set_longdata(const char *str, ulong length);
|
2002-11-06 14:01:12 +01:00
|
|
|
void set_long_end();
|
2003-01-24 07:32:39 +01:00
|
|
|
void set_time(TIME *tm, timestamp_type type);
|
|
|
|
bool get_time(TIME *tm);
|
2004-05-04 17:08:19 +02:00
|
|
|
void reset();
|
2004-03-15 18:20:47 +01:00
|
|
|
/*
|
|
|
|
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);
|
|
|
|
|
2002-06-12 23:13:12 +02:00
|
|
|
enum Item_result result_type () const
|
2002-11-06 14:01:12 +01:00
|
|
|
{ return item_result_type; }
|
2003-04-04 19:33:17 +02:00
|
|
|
String *query_val_str(String *str);
|
2002-12-11 08:17:51 +01:00
|
|
|
enum_field_types field_type() const { return MYSQL_TYPE_STRING; }
|
2003-04-04 19:33:17 +02:00
|
|
|
Item *new_item() { return new Item_param(pos_in_query); }
|
2003-11-22 22:48:18 +01:00
|
|
|
/*
|
|
|
|
If value for parameter was not set we treat it as non-const
|
|
|
|
so noone will use parameters value in fix_fields still
|
|
|
|
parameter is constant during execution.
|
|
|
|
*/
|
|
|
|
virtual table_map used_tables() const
|
|
|
|
{ return value_is_set ? (table_map)0 : PARAM_TABLE_BIT; }
|
2003-10-16 14:54:47 +02:00
|
|
|
void print(String *str) { str->append('?'); }
|
2002-06-12 23:13:12 +02:00
|
|
|
};
|
2000-07-31 21:29:14 +02:00
|
|
|
|
2004-03-18 17:27:03 +01:00
|
|
|
class Item_int :public Item_num
|
2000-07-31 21:29:14 +02:00
|
|
|
{
|
|
|
|
public:
|
2004-03-18 17:27:03 +01:00
|
|
|
longlong value;
|
2000-07-31 21:29:14 +02:00
|
|
|
Item_int(int32 i,uint length=11) :value((longlong) i)
|
2003-11-23 01:01:15 +01:00
|
|
|
{ max_length=length; fixed= 1; }
|
2000-07-31 21:29:14 +02:00
|
|
|
#ifdef HAVE_LONG_LONG
|
|
|
|
Item_int(longlong i,uint length=21) :value(i)
|
2003-11-23 01:01:15 +01:00
|
|
|
{ max_length=length; fixed= 1;}
|
2000-07-31 21:29:14 +02:00
|
|
|
#endif
|
|
|
|
Item_int(const char *str_arg,longlong i,uint length) :value(i)
|
2003-11-23 01:01:15 +01:00
|
|
|
{ max_length=length; name=(char*) str_arg; fixed= 1; }
|
2000-07-31 21:29:14 +02:00
|
|
|
Item_int(const char *str_arg) :
|
|
|
|
value(str_arg[0] == '-' ? strtoll(str_arg,(char**) 0,10) :
|
|
|
|
(longlong) strtoull(str_arg,(char**) 0,10))
|
2003-11-23 01:01:15 +01:00
|
|
|
{ max_length= (uint) strlen(str_arg); name=(char*) str_arg; fixed= 1; }
|
2000-07-31 21:29:14 +02:00
|
|
|
enum Type type() const { return INT_ITEM; }
|
2002-12-11 08:17:51 +01:00
|
|
|
enum Item_result result_type () const { return INT_RESULT; }
|
|
|
|
enum_field_types field_type() const { return MYSQL_TYPE_LONGLONG; }
|
2004-03-18 14:14:36 +01:00
|
|
|
longlong val_int() { DBUG_ASSERT(fixed == 1); return value; }
|
|
|
|
double val() { DBUG_ASSERT(fixed == 1); return (double) value; }
|
2000-07-31 21:29:14 +02:00
|
|
|
String *val_str(String*);
|
2002-12-05 18:38:42 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions);
|
2000-07-31 21:29:14 +02:00
|
|
|
bool basic_const_item() const { return 1; }
|
|
|
|
Item *new_item() { return new Item_int(name,value,max_length); }
|
2004-03-17 13:26:26 +01:00
|
|
|
// to prevent drop fixed flag (no need parent cleanup call)
|
2004-03-20 12:36:26 +01:00
|
|
|
void cleanup() {}
|
2004-03-18 17:27:03 +01:00
|
|
|
void print(String *str);
|
2004-03-20 12:36:26 +01:00
|
|
|
Item_num *neg() { value= -value; return this; }
|
2004-03-18 17:27:03 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Item_uint :public Item_int
|
2001-09-14 01:54:33 +02:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_uint(const char *str_arg, uint length) :
|
2004-03-18 17:27:03 +01:00
|
|
|
Item_int(str_arg, (longlong) strtoull(str_arg, (char**) 0,10), length)
|
2004-03-17 15:40:04 +01:00
|
|
|
{ unsigned_flag= 1; }
|
2004-03-16 13:28:50 +01:00
|
|
|
Item_uint(uint32 i) :Item_int((longlong) i, 10)
|
2004-03-17 15:40:04 +01:00
|
|
|
{ unsigned_flag= 1; }
|
2004-03-18 14:14:36 +01:00
|
|
|
double val()
|
|
|
|
{ DBUG_ASSERT(fixed == 1); return ulonglong2double((ulonglong)value); }
|
2001-09-14 01:54:33 +02:00
|
|
|
String *val_str(String*);
|
|
|
|
Item *new_item() { return new Item_uint(name,max_length); }
|
2003-11-20 21:30:48 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions);
|
2001-09-14 01:54:33 +02:00
|
|
|
void print(String *str);
|
2004-03-20 12:36:26 +01:00
|
|
|
Item_num *neg ();
|
2001-09-14 01:54:33 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2004-03-18 17:27:03 +01:00
|
|
|
class Item_real :public Item_num
|
2000-07-31 21:29:14 +02:00
|
|
|
{
|
|
|
|
public:
|
2004-03-18 17:27:03 +01:00
|
|
|
double value;
|
2000-07-31 21:29:14 +02:00
|
|
|
// Item_real() :value(0) {}
|
2004-03-20 12:36:26 +01:00
|
|
|
Item_real(const char *str_arg, uint length) :value(my_atof(str_arg))
|
2000-07-31 21:29:14 +02:00
|
|
|
{
|
|
|
|
name=(char*) str_arg;
|
2001-12-05 12:03:00 +01:00
|
|
|
decimals=(uint8) nr_of_decimals(str_arg);
|
2000-07-31 21:29:14 +02:00
|
|
|
max_length=length;
|
2004-03-20 12:36:26 +01:00
|
|
|
fixed= 1;
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
|
|
|
Item_real(const char *str,double val_arg,uint decimal_par,uint length)
|
|
|
|
:value(val_arg)
|
|
|
|
{
|
|
|
|
name=(char*) str;
|
2001-12-05 12:03:00 +01:00
|
|
|
decimals=(uint8) decimal_par;
|
2000-07-31 21:29:14 +02:00
|
|
|
max_length=length;
|
2004-03-20 12:36:26 +01:00
|
|
|
fixed= 1;
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
2004-03-20 12:36:26 +01:00
|
|
|
Item_real(double value_par) :value(value_par) { fixed= 1; }
|
2002-12-05 18:38:42 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions);
|
2000-07-31 21:29:14 +02:00
|
|
|
enum Type type() const { return REAL_ITEM; }
|
2002-12-11 08:17:51 +01:00
|
|
|
enum_field_types field_type() const { return MYSQL_TYPE_DOUBLE; }
|
2004-03-18 14:14:36 +01:00
|
|
|
double val() { DBUG_ASSERT(fixed == 1); return value; }
|
|
|
|
longlong val_int()
|
|
|
|
{
|
|
|
|
DBUG_ASSERT(fixed == 1);
|
|
|
|
return (longlong) (value+(value > 0 ? 0.5 : -0.5));
|
|
|
|
}
|
2000-07-31 21:29:14 +02:00
|
|
|
String *val_str(String*);
|
|
|
|
bool basic_const_item() const { return 1; }
|
2004-03-20 12:36:26 +01:00
|
|
|
// to prevent drop fixed flag (no need parent cleanup call)
|
|
|
|
void cleanup() {}
|
2000-07-31 21:29:14 +02:00
|
|
|
Item *new_item() { return new Item_real(name,value,decimals,max_length); }
|
2004-03-20 12:36:26 +01:00
|
|
|
Item_num *neg() { value= -value; return this; }
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Item_float :public Item_real
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_float(const char *str,uint length) :Item_real(str,length)
|
|
|
|
{
|
|
|
|
decimals=NOT_FIXED_DEC;
|
|
|
|
max_length=DBL_DIG+8;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class Item_string :public Item
|
|
|
|
{
|
|
|
|
public:
|
2003-02-28 16:22:20 +01:00
|
|
|
Item_string(const char *str,uint length,
|
2003-06-24 12:11:07 +02:00
|
|
|
CHARSET_INFO *cs, Derivation dv= DERIVATION_COERCIBLE)
|
2000-07-31 21:29:14 +02:00
|
|
|
{
|
2003-08-05 09:52:37 +02:00
|
|
|
collation.set(cs, dv);
|
2004-01-19 16:16:30 +01:00
|
|
|
str_value.set_or_copy_aligned(str,length,cs);
|
2003-11-03 13:01:59 +01:00
|
|
|
/*
|
|
|
|
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
|
|
|
|
number of chars for a string of this type because we in create_field::
|
|
|
|
divide the max_length with mbmaxlen).
|
|
|
|
*/
|
2003-08-11 15:18:34 +02:00
|
|
|
max_length= str_value.numchars()*cs->mbmaxlen;
|
2003-03-17 18:56:34 +01:00
|
|
|
set_name(str, length, cs);
|
2000-07-31 21:29:14 +02:00
|
|
|
decimals=NOT_FIXED_DEC;
|
2004-03-18 14:14:36 +01:00
|
|
|
// it is constant => can be used without fix_fields (and frequently used)
|
|
|
|
fixed= 1;
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
2002-12-19 06:38:32 +01:00
|
|
|
Item_string(const char *name_par, const char *str, uint length,
|
2003-06-24 12:11:07 +02:00
|
|
|
CHARSET_INFO *cs, Derivation dv= DERIVATION_COERCIBLE)
|
2000-07-31 21:29:14 +02:00
|
|
|
{
|
2003-08-05 09:52:37 +02:00
|
|
|
collation.set(cs, dv);
|
2004-01-19 16:16:30 +01:00
|
|
|
str_value.set_or_copy_aligned(str,length,cs);
|
2003-08-11 15:18:34 +02:00
|
|
|
max_length= str_value.numchars()*cs->mbmaxlen;
|
2003-03-17 18:56:34 +01:00
|
|
|
set_name(name_par,0,cs);
|
2000-07-31 21:29:14 +02:00
|
|
|
decimals=NOT_FIXED_DEC;
|
2004-03-18 14:14:36 +01:00
|
|
|
// it is constant => can be used without fix_fields (and frequently used)
|
|
|
|
fixed= 1;
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
|
|
|
enum Type type() const { return STRING_ITEM; }
|
2002-12-09 11:58:24 +01:00
|
|
|
double val()
|
2004-03-18 14:14:36 +01:00
|
|
|
{
|
|
|
|
DBUG_ASSERT(fixed == 1);
|
2003-01-16 14:17:07 +01:00
|
|
|
int err;
|
2003-01-14 13:28:36 +01:00
|
|
|
return my_strntod(str_value.charset(), (char*) str_value.ptr(),
|
2003-01-16 14:17:07 +01:00
|
|
|
str_value.length(), (char**) 0, &err);
|
2002-12-09 11:58:24 +01:00
|
|
|
}
|
|
|
|
longlong val_int()
|
|
|
|
{
|
2004-03-18 14:14:36 +01:00
|
|
|
DBUG_ASSERT(fixed == 1);
|
2003-01-16 14:17:07 +01:00
|
|
|
int err;
|
2002-12-19 06:38:32 +01:00
|
|
|
return my_strntoll(str_value.charset(), str_value.ptr(),
|
2003-01-16 14:17:07 +01:00
|
|
|
str_value.length(), 10, (char**) 0, &err);
|
2002-12-09 11:58:24 +01:00
|
|
|
}
|
2004-03-18 14:14:36 +01:00
|
|
|
String *val_str(String*)
|
|
|
|
{
|
|
|
|
DBUG_ASSERT(fixed == 1);
|
|
|
|
return (String*) &str_value;
|
|
|
|
}
|
2002-12-05 18:38:42 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions);
|
2000-07-31 21:29:14 +02:00
|
|
|
enum Item_result result_type () const { return STRING_RESULT; }
|
2002-12-11 08:17:51 +01:00
|
|
|
enum_field_types field_type() const { return MYSQL_TYPE_STRING; }
|
2000-07-31 21:29:14 +02:00
|
|
|
bool basic_const_item() const { return 1; }
|
2002-03-22 13:03:42 +01:00
|
|
|
bool eq(const Item *item, bool binary_cmp) const;
|
2002-12-06 20:55:53 +01:00
|
|
|
Item *new_item()
|
|
|
|
{
|
2004-03-03 08:22:25 +01:00
|
|
|
return new Item_string(name, str_value.ptr(),
|
|
|
|
str_value.length(), &my_charset_bin);
|
2002-12-06 20:55:53 +01:00
|
|
|
}
|
2000-07-31 21:29:14 +02:00
|
|
|
String *const_string() { return &str_value; }
|
2002-12-06 20:55:53 +01:00
|
|
|
inline void append(char *str, uint length) { str_value.append(str, length); }
|
2000-07-31 21:29:14 +02:00
|
|
|
void print(String *str);
|
2004-03-20 12:36:26 +01:00
|
|
|
// to prevent drop fixed flag (no need parent cleanup call)
|
|
|
|
void cleanup() {}
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/* for show tables */
|
|
|
|
|
|
|
|
class Item_datetime :public Item_string
|
|
|
|
{
|
|
|
|
public:
|
2003-03-07 09:21:32 +01:00
|
|
|
Item_datetime(const char *item_name): Item_string(item_name,"",0,
|
|
|
|
&my_charset_bin)
|
2000-07-31 21:29:14 +02:00
|
|
|
{ max_length=19;}
|
2002-12-11 08:17:51 +01:00
|
|
|
enum_field_types field_type() const { return MYSQL_TYPE_DATETIME; }
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
class Item_empty_string :public Item_string
|
|
|
|
{
|
|
|
|
public:
|
2003-03-07 09:21:32 +01:00
|
|
|
Item_empty_string(const char *header,uint length) :Item_string("",0,
|
|
|
|
&my_charset_bin)
|
2000-07-31 21:29:14 +02:00
|
|
|
{ name=(char*) header; max_length=length;}
|
2003-08-21 21:14:02 +02:00
|
|
|
void make_field(Send_field *field);
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
2002-12-11 08:17:51 +01:00
|
|
|
class Item_return_int :public Item_int
|
|
|
|
{
|
|
|
|
enum_field_types int_field_type;
|
|
|
|
public:
|
|
|
|
Item_return_int(const char *name, uint length,
|
|
|
|
enum_field_types field_type_arg)
|
|
|
|
:Item_int(name, 0, length), int_field_type(field_type_arg)
|
|
|
|
{
|
|
|
|
unsigned_flag=1;
|
|
|
|
}
|
|
|
|
enum_field_types field_type() const { return int_field_type; }
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
class Item_varbinary :public Item
|
|
|
|
{
|
|
|
|
public:
|
2002-10-25 10:58:32 +02:00
|
|
|
Item_varbinary(const char *str,uint str_length);
|
2000-07-31 21:29:14 +02:00
|
|
|
enum Type type() const { return VARBIN_ITEM; }
|
2004-03-18 14:14:36 +01:00
|
|
|
double val()
|
|
|
|
{ DBUG_ASSERT(fixed == 1); return (double) Item_varbinary::val_int(); }
|
2000-07-31 21:29:14 +02:00
|
|
|
longlong val_int();
|
2004-03-20 12:36:26 +01:00
|
|
|
bool basic_const_item() const { return 1; }
|
2004-03-18 14:14:36 +01:00
|
|
|
String *val_str(String*) { DBUG_ASSERT(fixed == 1); return &str_value; }
|
2002-12-05 18:38:42 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions);
|
2003-05-06 05:20:16 +02:00
|
|
|
enum Item_result result_type () const { return STRING_RESULT; }
|
2002-12-11 08:17:51 +01:00
|
|
|
enum_field_types field_type() const { return MYSQL_TYPE_STRING; }
|
2004-03-20 12:36:26 +01:00
|
|
|
// to prevent drop fixed flag (no need parent cleanup call)
|
|
|
|
void cleanup() {}
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Item_result_field :public Item /* Item with result field */
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Field *result_field; /* Save result here */
|
|
|
|
Item_result_field() :result_field(0) {}
|
2003-09-02 18:56:55 +02:00
|
|
|
// Constructor used for Item_sum/Item_cond_and/or (see Item comment)
|
2004-01-19 16:53:25 +01:00
|
|
|
Item_result_field(THD *thd, Item_result_field *item):
|
|
|
|
Item(thd, item), result_field(item->result_field)
|
2003-01-30 17:07:39 +01:00
|
|
|
{}
|
2000-07-31 21:29:14 +02:00
|
|
|
~Item_result_field() {} /* Required with gcc 2.95 */
|
2003-08-29 15:24:03 +02:00
|
|
|
Field *get_tmp_table_field() { return result_field; }
|
2003-01-25 01:25:52 +01:00
|
|
|
Field *tmp_table_field(TABLE *t_arg) { return result_field; }
|
2001-10-31 17:27:49 +01:00
|
|
|
table_map used_tables() const { return 1; }
|
2000-07-31 21:29:14 +02:00
|
|
|
virtual void fix_length_and_dec()=0;
|
2003-01-28 07:38:28 +01:00
|
|
|
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);
|
|
|
|
}
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Item_ref :public Item_ident
|
|
|
|
{
|
|
|
|
public:
|
2003-12-30 11:08:19 +01:00
|
|
|
Field *result_field; /* Save result here */
|
2001-04-17 14:17:22 +02:00
|
|
|
Item **ref;
|
2003-12-30 11:08:19 +01:00
|
|
|
Item **hook_ptr; /* These two to restore */
|
|
|
|
Item *orig_item; /* things in 'cleanup()' */
|
|
|
|
Item_ref(Item **hook, Item *original,const char *db_par,
|
|
|
|
const char *table_name_par, const char *field_name_par)
|
|
|
|
:Item_ident(db_par,table_name_par,field_name_par),ref(0), hook_ptr(hook),
|
|
|
|
orig_item(original) {}
|
|
|
|
Item_ref(Item **item, Item **hook,
|
|
|
|
const char *table_name_par, const char *field_name_par)
|
|
|
|
:Item_ident(NullS,table_name_par,field_name_par),
|
|
|
|
ref(item), hook_ptr(hook), orig_item(hook ? *hook:0) {}
|
2003-01-30 17:07:39 +01:00
|
|
|
// Constructor need to process subselect with temporary tables (see Item)
|
2004-01-19 16:53:25 +01:00
|
|
|
Item_ref(THD *thd, Item_ref *item, Item **hook)
|
|
|
|
:Item_ident(thd, item), ref(item->ref),
|
2003-12-30 11:08:19 +01:00
|
|
|
hook_ptr(hook), orig_item(hook ? *hook : 0) {}
|
2000-07-31 21:29:14 +02:00
|
|
|
enum Type type() const { return REF_ITEM; }
|
2002-03-22 13:03:42 +01:00
|
|
|
bool eq(const Item *item, bool binary_cmp) const
|
2002-11-24 10:18:32 +01:00
|
|
|
{ return ref && (*ref)->eq(item, binary_cmp); }
|
2000-07-31 21:29:14 +02:00
|
|
|
double val()
|
|
|
|
{
|
|
|
|
double tmp=(*ref)->val_result();
|
2002-12-10 17:10:00 +01:00
|
|
|
null_value=(*ref)->null_value;
|
2000-07-31 21:29:14 +02:00
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
longlong val_int()
|
|
|
|
{
|
|
|
|
longlong tmp=(*ref)->val_int_result();
|
2002-12-10 17:10:00 +01:00
|
|
|
null_value=(*ref)->null_value;
|
2000-07-31 21:29:14 +02:00
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
String *val_str(String* tmp)
|
|
|
|
{
|
|
|
|
tmp=(*ref)->str_result(tmp);
|
2002-12-10 17:10:00 +01:00
|
|
|
null_value=(*ref)->null_value;
|
2000-07-31 21:29:14 +02:00
|
|
|
return tmp;
|
|
|
|
}
|
2002-03-02 08:51:24 +01:00
|
|
|
bool is_null()
|
|
|
|
{
|
|
|
|
(void) (*ref)->val_int_result();
|
2002-12-10 17:10:00 +01:00
|
|
|
return (*ref)->null_value;
|
2002-03-02 08:51:24 +01:00
|
|
|
}
|
2003-11-03 13:01:59 +01:00
|
|
|
bool get_date(TIME *ltime,uint fuzzydate)
|
2003-03-11 21:20:53 +01:00
|
|
|
{
|
|
|
|
return (null_value=(*ref)->get_date_result(ltime,fuzzydate));
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
2002-12-11 08:17:51 +01:00
|
|
|
bool send(Protocol *prot, String *tmp){ return (*ref)->send(prot, tmp); }
|
2000-07-31 21:29:14 +02:00
|
|
|
void make_field(Send_field *field) { (*ref)->make_field(field); }
|
2002-07-01 13:14:51 +02:00
|
|
|
bool fix_fields(THD *, struct st_table_list *, Item **);
|
2002-12-05 18:38:42 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions)
|
2002-12-03 12:08:25 +01:00
|
|
|
{ return (*ref)->save_in_field(field, no_conversions); }
|
2000-07-31 21:29:14 +02:00
|
|
|
void save_org_in_field(Field *field) { (*ref)->save_org_in_field(field); }
|
|
|
|
enum Item_result result_type () const { return (*ref)->result_type(); }
|
2002-12-11 08:17:51 +01:00
|
|
|
enum_field_types field_type() const { return (*ref)->field_type(); }
|
2000-07-31 21:29:14 +02:00
|
|
|
table_map used_tables() const { return (*ref)->used_tables(); }
|
2003-03-18 10:17:48 +01:00
|
|
|
void set_result_field(Field *field) { result_field= field; }
|
2003-01-28 07:38:28 +01:00
|
|
|
bool is_result_field() { return 1; }
|
|
|
|
void save_in_result_field(bool no_conversions)
|
|
|
|
{
|
|
|
|
(*ref)->save_in_field(result_field, no_conversions);
|
|
|
|
}
|
2003-02-10 16:59:16 +01:00
|
|
|
Item *real_item() { return *ref; }
|
2003-10-16 14:54:47 +02:00
|
|
|
void print(String *str);
|
2003-12-30 11:08:19 +01:00
|
|
|
void cleanup();
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
2002-12-06 20:55:53 +01:00
|
|
|
class Item_in_subselect;
|
|
|
|
class Item_ref_null_helper: public Item_ref
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
Item_in_subselect* owner;
|
|
|
|
public:
|
|
|
|
Item_ref_null_helper(Item_in_subselect* master, Item **item,
|
2003-02-10 16:59:16 +01:00
|
|
|
const char *table_name_par, const char *field_name_par):
|
2003-12-30 11:08:19 +01:00
|
|
|
Item_ref(item, NULL, table_name_par, field_name_par), owner(master) {}
|
2002-12-06 20:55:53 +01:00
|
|
|
double val();
|
|
|
|
longlong val_int();
|
|
|
|
String* val_str(String* s);
|
2003-11-03 13:01:59 +01:00
|
|
|
bool get_date(TIME *ltime, uint fuzzydate);
|
2003-10-16 14:54:47 +02:00
|
|
|
void print(String *str);
|
2002-12-06 20:55:53 +01:00
|
|
|
};
|
|
|
|
|
2003-08-16 01:04:29 +02:00
|
|
|
class Item_null_helper :public Item_ref_null_helper
|
|
|
|
{
|
|
|
|
Item *store;
|
|
|
|
public:
|
|
|
|
Item_null_helper(Item_in_subselect* master, Item *item,
|
|
|
|
const char *table_name_par, const char *field_name_par)
|
|
|
|
:Item_ref_null_helper(master, &store, table_name_par, field_name_par),
|
|
|
|
store(item)
|
|
|
|
{}
|
2003-10-16 14:54:47 +02:00
|
|
|
void print(String *str);
|
2003-08-16 01:04:29 +02:00
|
|
|
};
|
2002-12-19 20:15:09 +01:00
|
|
|
|
2002-05-15 00:01:26 +02:00
|
|
|
/*
|
|
|
|
The following class is used to optimize comparing of date columns
|
|
|
|
We need to save the original item, to be able to set the field to the
|
|
|
|
original value in 'opt_range'.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class Item_int_with_ref :public Item_int
|
|
|
|
{
|
|
|
|
Item *ref;
|
|
|
|
public:
|
|
|
|
Item_int_with_ref(longlong i, Item *ref_arg) :Item_int(i), ref(ref_arg)
|
|
|
|
{}
|
2002-12-05 18:38:42 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions)
|
2002-05-15 00:01:26 +02:00
|
|
|
{
|
2002-12-03 12:08:25 +01:00
|
|
|
return ref->save_in_field(field, no_conversions);
|
2002-05-15 00:01:26 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2002-10-02 12:33:08 +02:00
|
|
|
#include "gstream.h"
|
2002-02-22 12:24:42 +01:00
|
|
|
#include "spatial.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "item_sum.h"
|
|
|
|
#include "item_func.h"
|
2003-01-26 20:01:45 +01:00
|
|
|
#include "item_row.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "item_cmpfunc.h"
|
|
|
|
#include "item_strfunc.h"
|
2003-05-30 12:22:34 +02:00
|
|
|
#include "item_geofunc.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
#include "item_timefunc.h"
|
|
|
|
#include "item_uniq.h"
|
2002-05-12 22:46:42 +02:00
|
|
|
#include "item_subselect.h"
|
2000-07-31 21:29:14 +02:00
|
|
|
|
|
|
|
class Item_copy_string :public Item
|
|
|
|
{
|
2002-12-14 16:43:01 +01:00
|
|
|
enum enum_field_types cached_field_type;
|
2000-07-31 21:29:14 +02:00
|
|
|
public:
|
|
|
|
Item *item;
|
|
|
|
Item_copy_string(Item *i) :item(i)
|
|
|
|
{
|
|
|
|
null_value=maybe_null=item->maybe_null;
|
|
|
|
decimals=item->decimals;
|
|
|
|
max_length=item->max_length;
|
|
|
|
name=item->name;
|
2002-12-14 16:43:01 +01:00
|
|
|
cached_field_type= item->field_type();
|
2000-07-31 21:29:14 +02:00
|
|
|
}
|
|
|
|
enum Type type() const { return COPY_STR_ITEM; }
|
|
|
|
enum Item_result result_type () const { return STRING_RESULT; }
|
2002-12-14 16:43:01 +01:00
|
|
|
enum_field_types field_type() const { return cached_field_type; }
|
2000-07-31 21:29:14 +02:00
|
|
|
double val()
|
2003-01-14 13:28:36 +01:00
|
|
|
{
|
2003-01-16 14:17:07 +01:00
|
|
|
int err;
|
2003-01-14 13:28:36 +01:00
|
|
|
return (null_value ? 0.0 :
|
|
|
|
my_strntod(str_value.charset(), (char*) str_value.ptr(),
|
2003-01-16 14:17:07 +01:00
|
|
|
str_value.length(),NULL,&err));
|
2003-01-14 13:28:36 +01:00
|
|
|
}
|
2000-07-31 21:29:14 +02:00
|
|
|
longlong val_int()
|
2003-01-16 14:17:07 +01:00
|
|
|
{
|
|
|
|
int err;
|
|
|
|
return null_value ? LL(0) : my_strntoll(str_value.charset(),str_value.ptr(),str_value.length(),10, (char**) 0,&err);
|
|
|
|
}
|
2000-07-31 21:29:14 +02:00
|
|
|
String *val_str(String*);
|
|
|
|
void make_field(Send_field *field) { item->make_field(field); }
|
|
|
|
void copy();
|
2004-03-25 21:11:22 +01:00
|
|
|
int save_in_field(Field *field, bool no_conversions);
|
2000-07-31 21:29:14 +02:00
|
|
|
table_map used_tables() const { return (table_map) 1L; }
|
|
|
|
bool const_item() const { return 0; }
|
2001-10-04 01:44:18 +02:00
|
|
|
bool is_null() { return null_value; }
|
2000-07-31 21:29:14 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Item_buff :public Sql_alloc
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
my_bool null_value;
|
|
|
|
Item_buff() :null_value(0) {}
|
|
|
|
virtual bool cmp(void)=0;
|
|
|
|
virtual ~Item_buff(); /*line -e1509 */
|
|
|
|
};
|
|
|
|
|
|
|
|
class Item_str_buff :public Item_buff
|
|
|
|
{
|
|
|
|
Item *item;
|
|
|
|
String value,tmp_value;
|
|
|
|
public:
|
|
|
|
Item_str_buff(Item *arg) :item(arg),value(arg->max_length) {}
|
|
|
|
bool cmp(void);
|
|
|
|
~Item_str_buff(); // Deallocate String:s
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Item_real_buff :public Item_buff
|
|
|
|
{
|
|
|
|
Item *item;
|
|
|
|
double value;
|
|
|
|
public:
|
|
|
|
Item_real_buff(Item *item_par) :item(item_par),value(0.0) {}
|
|
|
|
bool cmp(void);
|
|
|
|
};
|
|
|
|
|
|
|
|
class Item_int_buff :public Item_buff
|
|
|
|
{
|
|
|
|
Item *item;
|
|
|
|
longlong value;
|
|
|
|
public:
|
|
|
|
Item_int_buff(Item *item_par) :item(item_par),value(0) {}
|
|
|
|
bool cmp(void);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Item_field_buff :public Item_buff
|
|
|
|
{
|
|
|
|
char *buff;
|
|
|
|
Field *field;
|
|
|
|
uint length;
|
|
|
|
|
|
|
|
public:
|
|
|
|
Item_field_buff(Item_field *item)
|
|
|
|
{
|
|
|
|
field=item->field;
|
|
|
|
buff= (char*) sql_calloc(length=field->pack_length());
|
|
|
|
}
|
|
|
|
bool cmp(void);
|
|
|
|
};
|
|
|
|
|
2003-01-05 11:07:24 +01:00
|
|
|
class Item_default_value : public Item_field
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item *arg;
|
2003-01-21 17:20:46 +01:00
|
|
|
Item_default_value() :
|
|
|
|
Item_field((const char *)NULL, (const char *)NULL, (const char *)NULL), arg(NULL) {}
|
2003-05-03 01:16:56 +02:00
|
|
|
Item_default_value(Item *a) :
|
2003-01-05 11:07:24 +01:00
|
|
|
Item_field((const char *)NULL, (const char *)NULL, (const char *)NULL), arg(a) {}
|
2003-01-22 17:08:12 +01:00
|
|
|
enum Type type() const { return DEFAULT_VALUE_ITEM; }
|
2003-01-05 11:07:24 +01:00
|
|
|
bool eq(const Item *item, bool binary_cmp) const;
|
|
|
|
bool fix_fields(THD *, struct st_table_list *, Item **);
|
2003-01-05 14:56:11 +01:00
|
|
|
void print(String *str);
|
2003-11-28 11:18:13 +01:00
|
|
|
int save_in_field(Field *field_arg, bool no_conversions)
|
2003-01-21 17:20:46 +01:00
|
|
|
{
|
|
|
|
if (!arg)
|
|
|
|
{
|
2003-11-28 11:18:13 +01:00
|
|
|
field_arg->set_default();
|
2003-01-21 17:20:46 +01:00
|
|
|
return 0;
|
|
|
|
}
|
2003-11-28 11:18:13 +01:00
|
|
|
return Item_field::save_in_field(field_arg, no_conversions);
|
2003-01-21 17:20:46 +01:00
|
|
|
}
|
2003-01-22 17:08:12 +01:00
|
|
|
table_map used_tables() const { return (table_map)0L; }
|
2003-07-02 12:12:18 +02:00
|
|
|
|
|
|
|
bool walk(Item_processor processor, byte *args)
|
|
|
|
{
|
|
|
|
return arg->walk(processor, args) ||
|
|
|
|
(this->*processor)(args);
|
|
|
|
}
|
2003-01-05 12:40:14 +01:00
|
|
|
};
|
2003-01-05 11:12:03 +01:00
|
|
|
|
2003-05-03 01:16:56 +02:00
|
|
|
class Item_insert_value : public Item_field
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item *arg;
|
|
|
|
Item_insert_value(Item *a) :
|
|
|
|
Item_field((const char *)NULL, (const char *)NULL, (const char *)NULL), arg(a) {}
|
|
|
|
bool eq(const Item *item, bool binary_cmp) const;
|
|
|
|
bool fix_fields(THD *, struct st_table_list *, Item **);
|
|
|
|
void print(String *str);
|
2003-11-28 11:18:13 +01:00
|
|
|
int save_in_field(Field *field_arg, bool no_conversions)
|
2003-05-03 01:16:56 +02:00
|
|
|
{
|
2003-11-28 11:18:13 +01:00
|
|
|
return Item_field::save_in_field(field_arg, no_conversions);
|
2003-05-03 01:16:56 +02:00
|
|
|
}
|
|
|
|
table_map used_tables() const { return (table_map)0L; }
|
2003-07-02 12:12:18 +02:00
|
|
|
|
|
|
|
bool walk(Item_processor processor, byte *args)
|
|
|
|
{
|
|
|
|
return arg->walk(processor, args) ||
|
|
|
|
(this->*processor)(args);
|
|
|
|
}
|
2003-05-03 01:16:56 +02:00
|
|
|
};
|
|
|
|
|
2002-12-19 06:38:32 +01:00
|
|
|
class Item_cache: public Item
|
|
|
|
{
|
2003-10-16 14:54:47 +02:00
|
|
|
protected:
|
|
|
|
Item *example;
|
2003-01-26 20:13:37 +01:00
|
|
|
table_map used_table_map;
|
2002-12-19 06:38:32 +01:00
|
|
|
public:
|
2003-10-16 14:54:47 +02:00
|
|
|
Item_cache(): example(0), used_table_map(0) {fixed= 1; null_value= 1;}
|
2003-01-26 20:13:37 +01:00
|
|
|
|
|
|
|
void set_used_tables(table_map map) { used_table_map= map; }
|
|
|
|
|
2004-03-20 12:36:26 +01:00
|
|
|
virtual bool allocate(uint i) { return 0; }
|
2003-12-25 15:50:22 +01:00
|
|
|
virtual bool setup(Item *item)
|
|
|
|
{
|
|
|
|
example= item;
|
|
|
|
max_length= item->max_length;
|
|
|
|
decimals= item->decimals;
|
|
|
|
collation.set(item->collation);
|
|
|
|
return 0;
|
|
|
|
};
|
2002-12-19 06:38:32 +01:00
|
|
|
virtual void store(Item *)= 0;
|
|
|
|
enum Type type() const { return CACHE_ITEM; }
|
2002-12-19 06:38:33 +01:00
|
|
|
static Item_cache* get_cache(Item_result type);
|
2003-01-26 20:13:37 +01:00
|
|
|
table_map used_tables() const { return used_table_map; }
|
2004-02-12 02:10:26 +01:00
|
|
|
virtual void keep_array() {}
|
2004-03-17 13:26:26 +01:00
|
|
|
// to prevent drop fixed flag (no need parent cleanup call)
|
2004-03-20 12:36:26 +01:00
|
|
|
void cleanup() {}
|
2003-10-16 14:54:47 +02:00
|
|
|
void print(String *str);
|
2002-12-19 06:38:32 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
class Item_cache_int: public Item_cache
|
|
|
|
{
|
|
|
|
longlong value;
|
|
|
|
public:
|
2003-01-26 20:13:37 +01:00
|
|
|
Item_cache_int(): Item_cache() {}
|
2002-12-19 06:38:32 +01:00
|
|
|
|
2003-10-16 14:54:47 +02:00
|
|
|
void store(Item *item);
|
2004-03-18 14:14:36 +01:00
|
|
|
double val() { DBUG_ASSERT(fixed == 1); return (double) value; }
|
|
|
|
longlong val_int() { DBUG_ASSERT(fixed == 1); return value; }
|
|
|
|
String* val_str(String *str)
|
|
|
|
{
|
|
|
|
DBUG_ASSERT(fixed == 1);
|
|
|
|
str->set(value, default_charset());
|
|
|
|
return str;
|
|
|
|
}
|
2002-12-19 06:38:32 +01:00
|
|
|
enum Item_result result_type() const { return INT_RESULT; }
|
|
|
|
};
|
|
|
|
|
|
|
|
class Item_cache_real: public Item_cache
|
|
|
|
{
|
|
|
|
double value;
|
|
|
|
public:
|
2003-01-26 20:13:37 +01:00
|
|
|
Item_cache_real(): Item_cache() {}
|
2003-12-25 15:50:22 +01:00
|
|
|
|
2003-10-16 14:54:47 +02:00
|
|
|
void store(Item *item);
|
2004-03-18 14:14:36 +01:00
|
|
|
double val() { DBUG_ASSERT(fixed == 1); return value; }
|
|
|
|
longlong val_int()
|
|
|
|
{
|
|
|
|
DBUG_ASSERT(fixed == 1);
|
|
|
|
return (longlong) (value+(value > 0 ? 0.5 : -0.5));
|
|
|
|
}
|
2002-12-19 06:38:32 +01:00
|
|
|
String* val_str(String *str)
|
|
|
|
{
|
2003-03-03 07:53:08 +01:00
|
|
|
str->set(value, decimals, default_charset());
|
2002-12-19 06:38:32 +01:00
|
|
|
return str;
|
|
|
|
}
|
|
|
|
enum Item_result result_type() const { return REAL_RESULT; }
|
|
|
|
};
|
|
|
|
|
|
|
|
class Item_cache_str: public Item_cache
|
|
|
|
{
|
|
|
|
char buffer[80];
|
2003-06-26 14:07:42 +02:00
|
|
|
String *value, value_buff;
|
2002-12-19 06:38:32 +01:00
|
|
|
public:
|
2003-01-26 20:13:37 +01:00
|
|
|
Item_cache_str(): Item_cache() { }
|
2002-12-19 06:38:32 +01:00
|
|
|
|
2002-12-19 06:38:33 +01:00
|
|
|
void store(Item *item);
|
|
|
|
double val();
|
|
|
|
longlong val_int();
|
2004-03-18 14:14:36 +01:00
|
|
|
String* val_str(String *) { DBUG_ASSERT(fixed == 1); return value; }
|
2002-12-19 06:38:32 +01:00
|
|
|
enum Item_result result_type() const { return STRING_RESULT; }
|
|
|
|
CHARSET_INFO *charset() const { return value->charset(); };
|
|
|
|
};
|
|
|
|
|
2002-12-19 20:15:09 +01:00
|
|
|
class Item_cache_row: public Item_cache
|
|
|
|
{
|
|
|
|
Item_cache **values;
|
2002-12-28 00:01:05 +01:00
|
|
|
uint item_count;
|
2004-02-12 02:10:26 +01:00
|
|
|
bool save_array;
|
2002-12-19 20:15:09 +01:00
|
|
|
public:
|
2004-02-12 02:10:26 +01:00
|
|
|
Item_cache_row()
|
|
|
|
:Item_cache(), values(0), item_count(2), save_array(0) {}
|
2002-12-19 20:15:09 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
'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");
|
|
|
|
};
|
|
|
|
double val()
|
|
|
|
{
|
|
|
|
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;
|
|
|
|
};
|
|
|
|
enum Item_result result_type() const { return ROW_RESULT; }
|
|
|
|
|
2002-12-28 00:01:05 +01:00
|
|
|
uint cols() { return item_count; }
|
2002-12-19 20:15:09 +01:00
|
|
|
Item* el(uint i) { return values[i]; }
|
|
|
|
Item** addr(uint i) { return (Item **) (values + i); }
|
|
|
|
bool check_cols(uint c);
|
|
|
|
bool null_inside();
|
|
|
|
void bring_value();
|
2004-02-12 02:10:26 +01:00
|
|
|
void keep_array() { save_array= 1; }
|
2003-12-30 11:08:19 +01:00
|
|
|
void cleanup()
|
|
|
|
{
|
2004-02-08 19:14:13 +01:00
|
|
|
DBUG_ENTER("Item_cache_row::cleanup");
|
2003-12-30 11:08:19 +01:00
|
|
|
Item_cache::cleanup();
|
2004-02-12 02:10:26 +01:00
|
|
|
if (save_array)
|
|
|
|
bzero(values, item_count*sizeof(Item**));
|
|
|
|
else
|
|
|
|
values= 0;
|
2004-02-08 19:14:13 +01:00
|
|
|
DBUG_VOID_RETURN;
|
2003-12-30 11:08:19 +01:00
|
|
|
}
|
2002-12-19 20:15:09 +01:00
|
|
|
};
|
|
|
|
|
2003-11-23 01:01:15 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
Used to store type. name, length of Item for UNIONS & derived table
|
|
|
|
*/
|
|
|
|
class Item_type_holder: public Item
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
Item_result item_type;
|
2004-01-20 17:55:47 +01:00
|
|
|
Item_result orig_type;
|
2003-11-23 01:01:15 +01:00
|
|
|
Field *field_example;
|
|
|
|
public:
|
|
|
|
Item_type_holder(THD*, Item*);
|
|
|
|
|
|
|
|
Item_result result_type () const { return item_type; }
|
|
|
|
enum Type type() const { return TYPE_HOLDER; }
|
|
|
|
double val();
|
|
|
|
longlong val_int();
|
|
|
|
String *val_str(String*);
|
2003-11-25 22:52:10 +01:00
|
|
|
bool join_types(THD *thd, Item *);
|
2003-11-23 01:01:15 +01:00
|
|
|
Field *example() { return field_example; }
|
2004-01-20 17:55:47 +01:00
|
|
|
void cleanup()
|
|
|
|
{
|
2004-02-08 19:14:13 +01:00
|
|
|
DBUG_ENTER("Item_type_holder::cleanup");
|
2004-01-20 17:55:47 +01:00
|
|
|
Item::cleanup();
|
|
|
|
item_type= orig_type;
|
2004-02-08 19:14:13 +01:00
|
|
|
DBUG_VOID_RETURN;
|
2004-01-20 17:55:47 +01:00
|
|
|
}
|
2003-11-23 01:01:15 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2000-07-31 21:29:14 +02:00
|
|
|
extern Item_buff *new_Item_buff(Item *item);
|
|
|
|
extern Item_result item_cmp_type(Item_result a,Item_result b);
|
|
|
|
extern Item *resolve_const_item(Item *item,Item *cmp_item);
|
|
|
|
extern bool field_is_equal_to_item(Field *field,Item *item);
|