Commit 5fc21bc1 authored by bell@sanja.is.com.ua's avatar bell@sanja.is.com.ua

postreview fix (SCRUM)

NULL fixed
max_length fixed
layout fixed
parent 2885d552
...@@ -9,7 +9,7 @@ row(1,2,3) IN (row(3,NULL,3), row(1,2,3), row(1,3,3)) ...@@ -9,7 +9,7 @@ row(1,2,3) IN (row(3,NULL,3), row(1,2,3), row(1,3,3))
1 1
select row(10,2,3) IN (row(3,NULL,3), row(1,2,3), row(1,3,3)); select row(10,2,3) IN (row(3,NULL,3), row(1,2,3), row(1,3,3));
row(10,2,3) IN (row(3,NULL,3), row(1,2,3), row(1,3,3)) row(10,2,3) IN (row(3,NULL,3), row(1,2,3), row(1,3,3))
NULL 0
select row('a',1.5,3) IN (row(1,2,3), row('a',1.5,3), row('a','a','a')); select row('a',1.5,3) IN (row(1,2,3), row('a',1.5,3), row('a','a','a'));
row('a',1.5,3) IN (row(1,2,3), row('a',1.5,3), row('a','a','a')) row('a',1.5,3) IN (row(1,2,3), row('a',1.5,3), row('a','a','a'))
1 1
...@@ -24,7 +24,13 @@ row('a',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3)) ...@@ -24,7 +24,13 @@ row('a',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3))
1 1
select row('b',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3)); select row('b',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3));
row('b',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3)) row('b',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3))
0
select row('b',1.5,3) IN (row('b',NULL,3), row('a',1.5,3), row(1,3,3));
row('b',1.5,3) IN (row('b',NULL,3), row('a',1.5,3), row(1,3,3))
NULL NULL
select row('b',1.5,3) IN (row('b',NULL,4), row('a',1.5,3), row(1,3,3));
row('b',1.5,3) IN (row('b',NULL,4), row('a',1.5,3), row(1,3,3))
0
select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,4))); select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,4)));
row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,4))) row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,4)))
1 1
......
...@@ -7,6 +7,8 @@ select row('a',0,3) IN (row(3,2,3), row('a','0','3'), row(1,3,3)); ...@@ -7,6 +7,8 @@ select row('a',0,3) IN (row(3,2,3), row('a','0','3'), row(1,3,3));
select row('a',0,3) IN (row(3,2,3), row('a','a','3'), row(1,3,3)); select row('a',0,3) IN (row(3,2,3), row('a','a','3'), row(1,3,3));
select row('a',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3)); select row('a',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3));
select row('b',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3)); select row('b',1.5,3) IN (row(3,NULL,3), row('a',1.5,3), row(1,3,3));
select row('b',1.5,3) IN (row('b',NULL,3), row('a',1.5,3), row(1,3,3));
select row('b',1.5,3) IN (row('b',NULL,4), row('a',1.5,3), row(1,3,3));
select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,4))); select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,row(3,4)));
-- error 1239 -- error 1239
select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,4)); select row(1,2,row(3,4)) IN (row(3,2,row(3,4)), row(1,2,4));
......
...@@ -537,19 +537,19 @@ bool Item_asterisk_remover::fix_fields(THD *thd, ...@@ -537,19 +537,19 @@ bool Item_asterisk_remover::fix_fields(THD *thd,
double Item_ref_null_helper::val() double Item_ref_null_helper::val()
{ {
double tmp= (*ref)->val_result(); double tmp= (*ref)->val_result();
owner->was_null|= null_value= (*ref)->is_null_result(); owner->was_null|= null_value= (*ref)->null_value;
return tmp; return tmp;
} }
longlong Item_ref_null_helper::val_int() longlong Item_ref_null_helper::val_int()
{ {
longlong tmp= (*ref)->val_int_result(); longlong tmp= (*ref)->val_int_result();
owner->was_null|= null_value= (*ref)->is_null_result(); owner->was_null|= null_value= (*ref)->null_value;
return tmp; return tmp;
} }
String* Item_ref_null_helper::val_str(String* s) String* Item_ref_null_helper::val_str(String* s)
{ {
String* tmp= (*ref)->str_result(s); String* tmp= (*ref)->str_result(s);
owner->was_null|= null_value= (*ref)->is_null_result(); owner->was_null|= null_value= (*ref)->null_value;
return tmp; return tmp;
} }
bool Item_ref_null_helper::get_date(TIME *ltime, bool fuzzydate) bool Item_ref_null_helper::get_date(TIME *ltime, bool fuzzydate)
......
...@@ -72,7 +72,6 @@ class Item { ...@@ -72,7 +72,6 @@ class Item {
virtual double val_result() { return val(); } virtual double val_result() { return val(); }
virtual longlong val_int_result() { return val_int(); } virtual longlong val_int_result() { return val_int(); }
virtual String *str_result(String* tmp) { return val_str(tmp); } virtual String *str_result(String* tmp) { return val_str(tmp); }
virtual bool is_null_result() { return is_null(); }
virtual table_map used_tables() const { return (table_map) 0L; } virtual table_map used_tables() const { return (table_map) 0L; }
virtual bool basic_const_item() const { return 0; } virtual bool basic_const_item() const { return 0; }
virtual Item *new_item() { return 0; } /* Only for const items */ virtual Item *new_item() { return 0; } /* Only for const items */
...@@ -100,6 +99,8 @@ class Item { ...@@ -100,6 +99,8 @@ class Item {
virtual Item* el(uint i) { return this; } virtual Item* el(uint i) { return this; }
virtual Item** addr(uint i) { return 0; } virtual Item** addr(uint i) { return 0; }
virtual bool check_cols(uint c); virtual bool check_cols(uint c);
// It is not row => null inside is impossible
virtual bool null_inside() { return 0; };
}; };
...@@ -124,13 +125,20 @@ class Item_wrapper :public Item ...@@ -124,13 +125,20 @@ class Item_wrapper :public Item
bool check_cols(uint col) { return item->check_cols(col); } bool check_cols(uint col) { return item->check_cols(col); }
bool eq(const Item *item, bool binary_cmp) const bool eq(const Item *item, bool binary_cmp) const
{ return item->eq(item, binary_cmp); } { return item->eq(item, binary_cmp); }
bool is_null() { return item->is_null_result(); } bool is_null()
{
item->val_int();
return item->null_value;
}
bool get_date(TIME *ltime, bool fuzzydate) bool get_date(TIME *ltime, bool fuzzydate)
{ {
return (null_value=item->get_date(ltime, fuzzydate)); return (null_value=item->get_date(ltime, fuzzydate));
} }
bool send(THD *thd, String *tmp) { return item->send(thd, tmp); } bool send(THD *thd, String *tmp) { return item->send(thd, tmp); }
int save_in_field(Field *field) { return item->save_in_field(field); } int save_in_field(Field *field, bool no_conversions)
{
return item->save_in_field(field, no_conversions);
}
void save_org_in_field(Field *field) { item->save_org_in_field(field); } void save_org_in_field(Field *field) { item->save_org_in_field(field); }
enum Item_result result_type () const { return item->result_type(); } enum Item_result result_type () const { return item->result_type(); }
table_map used_tables() const { return item->used_tables(); } table_map used_tables() const { return item->used_tables(); }
...@@ -187,7 +195,6 @@ class Item_field :public Item_ident ...@@ -187,7 +195,6 @@ class Item_field :public Item_ident
double val_result(); double val_result();
longlong val_int_result(); longlong val_int_result();
String *str_result(String* tmp); String *str_result(String* tmp);
bool is_null_result() { return result_field->is_null(); }
bool send(THD *thd, String *str_arg) bool send(THD *thd, String *str_arg)
{ {
return result_field->send(thd,str_arg); return result_field->send(thd,str_arg);
...@@ -473,25 +480,25 @@ class Item_ref :public Item_ident ...@@ -473,25 +480,25 @@ class Item_ref :public Item_ident
double val() double val()
{ {
double tmp=(*ref)->val_result(); double tmp=(*ref)->val_result();
null_value=(*ref)->is_null_result(); null_value=(*ref)->null_value;
return tmp; return tmp;
} }
longlong val_int() longlong val_int()
{ {
longlong tmp=(*ref)->val_int_result(); longlong tmp=(*ref)->val_int_result();
null_value=(*ref)->is_null_result(); null_value=(*ref)->null_value;
return tmp; return tmp;
} }
String *val_str(String* tmp) String *val_str(String* tmp)
{ {
tmp=(*ref)->str_result(tmp); tmp=(*ref)->str_result(tmp);
null_value=(*ref)->is_null_result(); null_value=(*ref)->null_value;
return tmp; return tmp;
} }
bool is_null() bool is_null()
{ {
(void) (*ref)->val_int_result(); (void) (*ref)->val_int_result();
return (*ref)->is_null_result(); return (*ref)->null_value;
} }
bool get_date(TIME *ltime,bool fuzzydate) bool get_date(TIME *ltime,bool fuzzydate)
{ {
......
...@@ -90,7 +90,7 @@ static bool convert_constant_item(Field *field, Item **item) ...@@ -90,7 +90,7 @@ static bool convert_constant_item(Field *field, Item **item)
void Item_bool_func2::fix_length_and_dec() void Item_bool_func2::fix_length_and_dec()
{ {
max_length=1; // Function returns 0 or 1 max_length= 1; // Function returns 0 or 1
/* /*
As some compare functions are generated after sql_yacc, As some compare functions are generated after sql_yacc,
...@@ -276,13 +276,13 @@ longlong Item_in_optimizer::val_int() ...@@ -276,13 +276,13 @@ longlong Item_in_optimizer::val_int()
flt_cache_ok= 0; flt_cache_ok= 0;
str_cache_ok= 0; str_cache_ok= 0;
int_cache= args[0]->val_int_result(); int_cache= args[0]->val_int_result();
if (args[0]->is_null_result()) if (args[0]->null_value)
{ {
null_value= 1; null_value= 1;
return 0; return 0;
} }
longlong tmp= args[1]->val_int_result(); longlong tmp= args[1]->val_int_result();
null_value= args[1]->is_null_result(); null_value= args[1]->null_value;
return tmp; return tmp;
} }
...@@ -294,7 +294,7 @@ longlong Item_in_optimizer::get_cache_int() ...@@ -294,7 +294,7 @@ longlong Item_in_optimizer::get_cache_int()
flt_cache_ok= 0; flt_cache_ok= 0;
str_cache_ok= 0; str_cache_ok= 0;
int_cache= args[0]->val_int_result(); int_cache= args[0]->val_int_result();
null_value= args[0]->is_null_result(); null_value= args[0]->null_value;
} }
return int_cache; return int_cache;
} }
...@@ -303,11 +303,11 @@ double Item_in_optimizer::get_cache() ...@@ -303,11 +303,11 @@ double Item_in_optimizer::get_cache()
{ {
if (!flt_cache_ok) if (!flt_cache_ok)
{ {
int_cache_ok= 0;
flt_cache_ok= 1; flt_cache_ok= 1;
int_cache_ok= 0;
str_cache_ok= 0; str_cache_ok= 0;
flt_cache= args[0]->val_result(); flt_cache= args[0]->val_result();
null_value= args[0]->is_null_result(); null_value= args[0]->null_value;
} }
return flt_cache; return flt_cache;
} }
...@@ -316,12 +316,12 @@ String *Item_in_optimizer::get_cache_str(String *s) ...@@ -316,12 +316,12 @@ String *Item_in_optimizer::get_cache_str(String *s)
{ {
if (!str_cache_ok) if (!str_cache_ok)
{ {
str_cache_ok= 1;
int_cache_ok= 0; int_cache_ok= 0;
flt_cache_ok= 0; flt_cache_ok= 0;
str_cache_ok= 1; str_value.set(buffer, sizeof(buffer), s->charset());
str_cache_buff.set(buffer, sizeof(buffer), s->charset()); str_cache= args[0]->str_result(&str_value);
str_cache= args[0]->str_result(&str_cache_buff); null_value= args[0]->null_value;
null_value= args[0]->is_null_result();
} }
return str_cache; return str_cache;
} }
...@@ -418,7 +418,8 @@ void Item_func_interval::fix_length_and_dec() ...@@ -418,7 +418,8 @@ void Item_func_interval::fix_length_and_dec()
intervals[i]=args[i]->val(); intervals[i]=args[i]->val();
} }
} }
maybe_null=0; max_length=2; maybe_null= 0;
max_length= 2;
used_tables_cache|=item->used_tables(); used_tables_cache|=item->used_tables();
} }
...@@ -477,7 +478,7 @@ bool Item_func_interval::check_loop(uint id) ...@@ -477,7 +478,7 @@ bool Item_func_interval::check_loop(uint id)
void Item_func_between::fix_length_and_dec() void Item_func_between::fix_length_and_dec()
{ {
max_length=1; max_length= 1;
/* /*
As some compare functions are generated after sql_yacc, As some compare functions are generated after sql_yacc,
...@@ -1030,8 +1031,8 @@ double Item_func_coalesce::val() ...@@ -1030,8 +1031,8 @@ double Item_func_coalesce::val()
void Item_func_coalesce::fix_length_and_dec() void Item_func_coalesce::fix_length_and_dec()
{ {
max_length=0; max_length= 0;
decimals=0; decimals= 0;
cached_result_type = args[0]->result_type(); cached_result_type = args[0]->result_type();
for (uint i=0 ; i < arg_count ; i++) for (uint i=0 ; i < arg_count ; i++)
{ {
...@@ -1214,8 +1215,9 @@ cmp_item* cmp_item_row::make_same() ...@@ -1214,8 +1215,9 @@ cmp_item* cmp_item_row::make_same()
void cmp_item_row::store_value(Item *item) void cmp_item_row::store_value(Item *item)
{ {
THD *thd= current_thd;
n= item->cols(); n= item->cols();
if ((comparators= (cmp_item **) sql_alloc(sizeof(cmp_item *)*n))) if ((comparators= (cmp_item **) thd->alloc(sizeof(cmp_item *)*n)))
{ {
item->null_value= 0; item->null_value= 0;
for (uint i=0; i < n; i++) for (uint i=0; i < n; i++)
...@@ -1227,14 +1229,14 @@ void cmp_item_row::store_value(Item *item) ...@@ -1227,14 +1229,14 @@ void cmp_item_row::store_value(Item *item)
else else
{ {
my_message(ER_OUT_OF_RESOURCES, ER(ER_OUT_OF_RESOURCES), MYF(0)); my_message(ER_OUT_OF_RESOURCES, ER(ER_OUT_OF_RESOURCES), MYF(0));
current_thd->fatal_error= 1; thd->fatal_error= 1;
return; return;
} }
} }
else else
{ {
my_message(ER_OUT_OF_RESOURCES, ER(ER_OUT_OF_RESOURCES), MYF(0)); my_message(ER_OUT_OF_RESOURCES, ER(ER_OUT_OF_RESOURCES), MYF(0));
current_thd->fatal_error= 1; thd->fatal_error= 1;
return; return;
} }
} }
...@@ -1281,33 +1283,53 @@ int cmp_item_row::cmp(Item *arg) ...@@ -1281,33 +1283,53 @@ int cmp_item_row::cmp(Item *arg)
my_error(ER_CARDINALITY_COL, MYF(0), n); my_error(ER_CARDINALITY_COL, MYF(0), n);
return 1; return 1;
} }
for(uint i=0; i < n; i++) bool was_null= 0;
if(comparators[i]->cmp(arg->el(i))) for (uint i=0; i < n; i++)
if (comparators[i]->cmp(arg->el(i)))
{ {
arg->null_value|= arg->el(i)->null_value; if (!arg->el(i)->null_value)
return 1; return 1;
was_null= 1;
} }
if (!was_null)
return 0; return 0;
arg->null_value= 1;
return 1;
} }
int cmp_item_row::compare(cmp_item *c) int cmp_item_row::compare(cmp_item *c)
{ {
int res; int res;
cmp_item_row *cmp= (cmp_item_row *) c; cmp_item_row *cmp= (cmp_item_row *) c;
for(uint i=0; i < n; i++) for (uint i=0; i < n; i++)
if((res= comparators[i]->compare(cmp->comparators[i]))) if ((res= comparators[i]->compare(cmp->comparators[i])))
return res; return res;
return 0; return 0;
} }
bool Item_func_in::nulls_in_row()
{
Item **arg,**arg_end;
for (arg= args, arg_end= args+arg_count; arg != arg_end ; arg++)
{
if ((*arg)->null_inside())
return 1;
}
return 0;
}
void Item_func_in::fix_length_and_dec() void Item_func_in::fix_length_and_dec()
{ {
if (const_item()) /*
Row item with NULLs inside can return NULL or FALSE =>
they can't be processed as static
*/
if (const_item() && !nulls_in_row())
{ {
switch (item->result_type()) { switch (item->result_type()) {
case STRING_RESULT: case STRING_RESULT:
if (item->binary()) if (item->binary())
array=new in_string(arg_count,(qsort_cmp) stringcmp); /* purecov: inspected */ array=new in_string(arg_count,(qsort_cmp) stringcmp);
else else
array=new in_string(arg_count,(qsort_cmp) sortcmp); array=new in_string(arg_count,(qsort_cmp) sortcmp);
break; break;
...@@ -1338,7 +1360,7 @@ void Item_func_in::fix_length_and_dec() ...@@ -1338,7 +1360,7 @@ void Item_func_in::fix_length_and_dec()
in_item= cmp_item:: get_comparator(item); in_item= cmp_item:: get_comparator(item);
} }
maybe_null= item->maybe_null; maybe_null= item->maybe_null;
max_length=2; max_length= 1;
used_tables_cache|=item->used_tables(); used_tables_cache|=item->used_tables();
const_item_cache&=item->const_item(); const_item_cache&=item->const_item();
} }
...@@ -1661,7 +1683,8 @@ longlong Item_func_isnotnull::val_int() ...@@ -1661,7 +1683,8 @@ longlong Item_func_isnotnull::val_int()
void Item_func_like::fix_length_and_dec() void Item_func_like::fix_length_and_dec()
{ {
decimals=0; max_length=1; decimals= 0;
max_length= 1;
// cmp_type=STRING_RESULT; // For quick select // cmp_type=STRING_RESULT; // For quick select
} }
...@@ -1768,7 +1791,8 @@ Item_func_regex::fix_fields(THD *thd, TABLE_LIST *tables, Item **ref) ...@@ -1768,7 +1791,8 @@ Item_func_regex::fix_fields(THD *thd, TABLE_LIST *tables, Item **ref)
args[1]->fix_fields(thd,tables, args + 1)) args[1]->fix_fields(thd,tables, args + 1))
return 1; /* purecov: inspected */ return 1; /* purecov: inspected */
with_sum_func=args[0]->with_sum_func || args[1]->with_sum_func; with_sum_func=args[0]->with_sum_func || args[1]->with_sum_func;
max_length=1; decimals=0; max_length= 1;
decimals= 0;
if (args[0]->binary() || args[1]->binary()) if (args[0]->binary() || args[1]->binary())
set_charset(my_charset_bin); set_charset(my_charset_bin);
......
...@@ -91,7 +91,7 @@ class Item_in_optimizer: public Item_bool_func ...@@ -91,7 +91,7 @@ class Item_in_optimizer: public Item_bool_func
char buffer[80]; char buffer[80];
longlong int_cache; longlong int_cache;
double flt_cache; double flt_cache;
String str_cache_buff, *str_cache; String *str_cache;
bool int_cache_ok, flt_cache_ok, str_cache_ok; bool int_cache_ok, flt_cache_ok, str_cache_ok;
public: public:
Item_in_optimizer(Item *a,Item *b): Item_in_optimizer(Item *a,Item *b):
...@@ -442,11 +442,14 @@ class cmp_item :public Sql_alloc ...@@ -442,11 +442,14 @@ class cmp_item :public Sql_alloc
} }
}; };
typedef int (*str_cmp_func_pointer)(const String *, const String *);
class cmp_item_string :public cmp_item class cmp_item_string :public cmp_item
{ {
protected: protected:
str_cmp_func_pointer str_cmp_func;
String *value_res; String *value_res;
public: public:
cmp_item_string (str_cmp_func_pointer cmp): str_cmp_func(cmp) {}
friend class cmp_item_sort_string; friend class cmp_item_sort_string;
friend class cmp_item_binary_string; friend class cmp_item_binary_string;
friend class cmp_item_sort_string_in_static; friend class cmp_item_sort_string_in_static;
...@@ -459,7 +462,11 @@ class cmp_item_sort_string :public cmp_item_string ...@@ -459,7 +462,11 @@ class cmp_item_sort_string :public cmp_item_string
char value_buff[80]; char value_buff[80];
String value; String value;
public: public:
cmp_item_sort_string(str_cmp_func_pointer cmp):
cmp_item_string(cmp),
value(value_buff, sizeof(value_buff), default_charset_info) {}
cmp_item_sort_string(): cmp_item_sort_string():
cmp_item_string(&sortcmp),
value(value_buff, sizeof(value_buff), default_charset_info) {} value(value_buff, sizeof(value_buff), default_charset_info) {}
void store_value(Item *item) void store_value(Item *item)
{ {
...@@ -471,32 +478,19 @@ class cmp_item_sort_string :public cmp_item_string ...@@ -471,32 +478,19 @@ class cmp_item_sort_string :public cmp_item_string
String tmp(buff, sizeof(buff), default_charset_info), *res; String tmp(buff, sizeof(buff), default_charset_info), *res;
if (!(res= arg->val_str(&tmp))) if (!(res= arg->val_str(&tmp)))
return 1; /* Can't be right */ return 1; /* Can't be right */
return sortcmp(value_res, res); return (*str_cmp_func)(value_res, res);
} }
int compare(cmp_item *c) int compare(cmp_item *c)
{ {
cmp_item_string *cmp= (cmp_item_string *)c; cmp_item_string *cmp= (cmp_item_string *)c;
return sortcmp(value_res, cmp->value_res); return (*str_cmp_func)(value_res, cmp->value_res);
} }
cmp_item *make_same(); cmp_item *make_same();
}; };
class cmp_item_binary_string :public cmp_item_sort_string { class cmp_item_binary_string :public cmp_item_sort_string {
public: public:
cmp_item_binary_string() {} cmp_item_binary_string(): cmp_item_sort_string(&stringcmp) {}
int cmp(Item *arg)
{
char buff[80];
String tmp(buff,sizeof(buff),default_charset_info),*res;
if (!(res=arg->val_str(&tmp)))
return 1; /* Can't be right */
return stringcmp(value_res,res);
}
int compare(cmp_item *c)
{
cmp_item_string *cmp= (cmp_item_string *)c;
return stringcmp(value_res, cmp->value_res);
}
cmp_item *make_same(); cmp_item *make_same();
}; };
...@@ -580,7 +574,9 @@ class cmp_item_sort_string_in_static :public cmp_item_string ...@@ -580,7 +574,9 @@ class cmp_item_sort_string_in_static :public cmp_item_string
protected: protected:
String value; String value;
public: public:
cmp_item_sort_string_in_static() {} cmp_item_sort_string_in_static(str_cmp_func_pointer cmp):
cmp_item_string(cmp) {}
cmp_item_sort_string_in_static(): cmp_item_string(&sortcmp) {}
void store_value(Item *item) void store_value(Item *item)
{ {
value_res= item->val_str(&value); value_res= item->val_str(&value);
...@@ -594,7 +590,7 @@ class cmp_item_sort_string_in_static :public cmp_item_string ...@@ -594,7 +590,7 @@ class cmp_item_sort_string_in_static :public cmp_item_string
int compare(cmp_item *c) int compare(cmp_item *c)
{ {
cmp_item_string *cmp= (cmp_item_string *)c; cmp_item_string *cmp= (cmp_item_string *)c;
return sortcmp(value_res, cmp->value_res); return (*str_cmp_func)(value_res, cmp->value_res);
} }
cmp_item * make_same() cmp_item * make_same()
{ {
...@@ -604,12 +600,8 @@ class cmp_item_sort_string_in_static :public cmp_item_string ...@@ -604,12 +600,8 @@ class cmp_item_sort_string_in_static :public cmp_item_string
class cmp_item_binary_string_in_static :public cmp_item_sort_string_in_static { class cmp_item_binary_string_in_static :public cmp_item_sort_string_in_static {
public: public:
cmp_item_binary_string_in_static() {} cmp_item_binary_string_in_static():
int compare(cmp_item *c) cmp_item_sort_string_in_static(&stringcmp) {}
{
cmp_item_string *cmp= (cmp_item_string *)c;
return stringcmp(value_res, cmp->value_res);
}
cmp_item * make_same() cmp_item * make_same()
{ {
return new cmp_item_binary_string_in_static(); return new cmp_item_binary_string_in_static();
...@@ -654,6 +646,7 @@ class Item_func_in :public Item_int_func ...@@ -654,6 +646,7 @@ class Item_func_in :public Item_int_func
DBUG_RETURN(1); DBUG_RETURN(1);
DBUG_RETURN(item->check_loop(id)); DBUG_RETURN(item->check_loop(id));
} }
bool nulls_in_row();
}; };
/* Functions used by where clause */ /* Functions used by where clause */
......
...@@ -81,3 +81,22 @@ bool Item_row::check_cols(uint c) ...@@ -81,3 +81,22 @@ bool Item_row::check_cols(uint c)
} }
return 0; return 0;
} }
bool Item_row::null_inside()
{
for (uint i= 0; i < arg_count; i++)
{
if (items[i]->cols() > 1)
{
if (items[i]->null_inside())
return 1;
}
else
{
items[i]->val_int();
if (items[i]->null_value)
return 1;
}
}
return 0;
}
...@@ -65,8 +65,9 @@ class Item_row: public Item ...@@ -65,8 +65,9 @@ class Item_row: public Item
enum Item_result result_type() const { return ROW_RESULT; } enum Item_result result_type() const { return ROW_RESULT; }
void update_used_tables(); void update_used_tables();
virtual uint cols() { return arg_count; } uint cols() { return arg_count; }
virtual Item* el(uint i) { return items[i]; } Item* el(uint i) { return items[i]; }
virtual Item** addr(uint i) { return items + i; } Item** addr(uint i) { return items + i; }
virtual bool check_cols(uint c); bool check_cols(uint c);
bool null_inside();
}; };
...@@ -933,7 +933,7 @@ bool select_singleval_subselect::send_data(List<Item> &items) ...@@ -933,7 +933,7 @@ bool select_singleval_subselect::send_data(List<Item> &items)
calculate value on it & determinate "is it NULL?". calculate value on it & determinate "is it NULL?".
*/ */
it->real_value= val_item->val_result(); it->real_value= val_item->val_result();
if ((it->null_value= val_item->is_null_result())) if ((it->null_value= val_item->null_value))
{ {
it->reset(); it->reset();
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment