Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
e978efd9
Commit
e978efd9
authored
Aug 07, 2019
by
Alexander Barkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MDEV-20273 Add class Item_sum_min_max
parent
a8def12e
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
108 additions
and
95 deletions
+108
-95
sql/item_cmpfunc.h
sql/item_cmpfunc.h
+2
-2
sql/item_subselect.cc
sql/item_subselect.cc
+1
-1
sql/item_sum.cc
sql/item_sum.cc
+38
-38
sql/item_sum.h
sql/item_sum.h
+34
-16
sql/item_windowfunc.h
sql/item_windowfunc.h
+5
-10
sql/sql_type.cc
sql/sql_type.cc
+15
-15
sql/sql_type.h
sql/sql_type.h
+11
-11
storage/spider/spd_db_conn.cc
storage/spider/spd_db_conn.cc
+2
-2
No files found.
sql/item_cmpfunc.h
View file @
e978efd9
...
@@ -654,7 +654,7 @@ class Item_func_trig_cond: public Item_bool_func
...
@@ -654,7 +654,7 @@ class Item_func_trig_cond: public Item_bool_func
class
Item_func_not_all
:
public
Item_func_not
class
Item_func_not_all
:
public
Item_func_not
{
{
/* allow to check presence of values in max/min optimization */
/* allow to check presence of values in max/min optimization */
Item_sum_
hybrid
*
test_sum_item
;
Item_sum_
min_max
*
test_sum_item
;
Item_maxmin_subselect
*
test_sub_item
;
Item_maxmin_subselect
*
test_sub_item
;
public:
public:
...
@@ -670,7 +670,7 @@ class Item_func_not_all :public Item_func_not
...
@@ -670,7 +670,7 @@ class Item_func_not_all :public Item_func_not
bool
fix_fields
(
THD
*
thd
,
Item
**
ref
)
bool
fix_fields
(
THD
*
thd
,
Item
**
ref
)
{
return
Item_func
::
fix_fields
(
thd
,
ref
);}
{
return
Item_func
::
fix_fields
(
thd
,
ref
);}
virtual
void
print
(
String
*
str
,
enum_query_type
query_type
);
virtual
void
print
(
String
*
str
,
enum_query_type
query_type
);
void
set_sum_test
(
Item_sum_
hybrid
*
item
)
{
test_sum_item
=
item
;
test_sub_item
=
0
;
};
void
set_sum_test
(
Item_sum_
min_max
*
item
)
{
test_sum_item
=
item
;
test_sub_item
=
0
;
};
void
set_sub_test
(
Item_maxmin_subselect
*
item
)
{
test_sub_item
=
item
;
test_sum_item
=
0
;};
void
set_sub_test
(
Item_maxmin_subselect
*
item
)
{
test_sub_item
=
item
;
test_sum_item
=
0
;};
bool
empty_underlying_subquery
();
bool
empty_underlying_subquery
();
Item
*
neg_transformer
(
THD
*
thd
);
Item
*
neg_transformer
(
THD
*
thd
);
...
...
sql/item_subselect.cc
View file @
e978efd9
...
@@ -1966,7 +1966,7 @@ bool Item_allany_subselect::transform_into_max_min(JOIN *join)
...
@@ -1966,7 +1966,7 @@ bool Item_allany_subselect::transform_into_max_min(JOIN *join)
(
!
select_lex
->
ref_pointer_array
[
0
]
->
maybe_null
||
/*4*/
(
!
select_lex
->
ref_pointer_array
[
0
]
->
maybe_null
||
/*4*/
substype
()
!=
Item_subselect
::
ALL_SUBS
))
/*4*/
substype
()
!=
Item_subselect
::
ALL_SUBS
))
/*4*/
{
{
Item_sum_
hybrid
*
item
;
Item_sum_
min_max
*
item
;
nesting_map
save_allow_sum_func
;
nesting_map
save_allow_sum_func
;
if
(
func
->
l_op
())
if
(
func
->
l_op
())
{
{
...
...
sql/item_sum.cc
View file @
e978efd9
...
@@ -1152,9 +1152,9 @@ Item_sum_num::fix_fields(THD *thd, Item **ref)
...
@@ -1152,9 +1152,9 @@ Item_sum_num::fix_fields(THD *thd, Item **ref)
bool
bool
Item_sum_
hybrid
::
fix_fields
(
THD
*
thd
,
Item
**
ref
)
Item_sum_
min_max
::
fix_fields
(
THD
*
thd
,
Item
**
ref
)
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::fix_fields"
);
DBUG_ENTER
(
"Item_sum_
min_max
::fix_fields"
);
DBUG_ASSERT
(
fixed
==
0
);
DBUG_ASSERT
(
fixed
==
0
);
if
(
init_sum_func_check
(
thd
))
if
(
init_sum_func_check
(
thd
))
...
@@ -1184,11 +1184,11 @@ Item_sum_hybrid::fix_fields(THD *thd, Item **ref)
...
@@ -1184,11 +1184,11 @@ Item_sum_hybrid::fix_fields(THD *thd, Item **ref)
}
}
bool
Item_sum_
hybrid
::
fix_length_and_dec
()
bool
Item_sum_
min_max
::
fix_length_and_dec
()
{
{
DBUG_ASSERT
(
args
[
0
]
->
field_type
()
==
args
[
0
]
->
real_item
()
->
field_type
());
DBUG_ASSERT
(
args
[
0
]
->
field_type
()
==
args
[
0
]
->
real_item
()
->
field_type
());
DBUG_ASSERT
(
args
[
0
]
->
result_type
()
==
args
[
0
]
->
real_item
()
->
result_type
());
DBUG_ASSERT
(
args
[
0
]
->
result_type
()
==
args
[
0
]
->
real_item
()
->
result_type
());
return
args
[
0
]
->
type_handler
()
->
Item_sum_
hybrid
_fix_length_and_dec
(
this
);
return
args
[
0
]
->
type_handler
()
->
Item_sum_
min_max
_fix_length_and_dec
(
this
);
}
}
...
@@ -1209,9 +1209,9 @@ bool Item_sum_hybrid::fix_length_and_dec()
...
@@ -1209,9 +1209,9 @@ bool Item_sum_hybrid::fix_length_and_dec()
and Item_sum_min::add() to use different values!
and Item_sum_min::add() to use different values!
*/
*/
void
Item_sum_
hybrid
::
setup_hybrid
(
THD
*
thd
,
Item
*
item
,
Item
*
value_arg
)
void
Item_sum_
min_max
::
setup_hybrid
(
THD
*
thd
,
Item
*
item
,
Item
*
value_arg
)
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::setup_hybrid"
);
DBUG_ENTER
(
"Item_sum_
min_max
::setup_hybrid"
);
if
(
!
(
value
=
item
->
get_cache
(
thd
)))
if
(
!
(
value
=
item
->
get_cache
(
thd
)))
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
value
->
setup
(
thd
,
item
);
value
->
setup
(
thd
,
item
);
...
@@ -1232,9 +1232,9 @@ void Item_sum_hybrid::setup_hybrid(THD *thd, Item *item, Item *value_arg)
...
@@ -1232,9 +1232,9 @@ void Item_sum_hybrid::setup_hybrid(THD *thd, Item *item, Item *value_arg)
}
}
Field
*
Item_sum_
hybrid
::
create_tmp_field
(
bool
group
,
TABLE
*
table
)
Field
*
Item_sum_
min_max
::
create_tmp_field
(
bool
group
,
TABLE
*
table
)
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::create_tmp_field"
);
DBUG_ENTER
(
"Item_sum_
min_max
::create_tmp_field"
);
if
(
args
[
0
]
->
type
()
==
Item
::
FIELD_ITEM
)
if
(
args
[
0
]
->
type
()
==
Item
::
FIELD_ITEM
)
{
{
...
@@ -2314,9 +2314,9 @@ Item *Item_sum_variance::result_item(THD *thd, Field *field)
...
@@ -2314,9 +2314,9 @@ Item *Item_sum_variance::result_item(THD *thd, Field *field)
/* min & max */
/* min & max */
void
Item_sum_
hybrid
::
clear
()
void
Item_sum_
min_max
::
clear
()
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::clear"
);
DBUG_ENTER
(
"Item_sum_
min_max
::clear"
);
value
->
clear
();
value
->
clear
();
null_value
=
1
;
null_value
=
1
;
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
...
@@ -2324,7 +2324,7 @@ void Item_sum_hybrid::clear()
...
@@ -2324,7 +2324,7 @@ void Item_sum_hybrid::clear()
bool
bool
Item_sum_
hybrid
::
get_date
(
MYSQL_TIME
*
ltime
,
ulonglong
fuzzydate
)
Item_sum_
min_max
::
get_date
(
MYSQL_TIME
*
ltime
,
ulonglong
fuzzydate
)
{
{
DBUG_ASSERT
(
fixed
==
1
);
DBUG_ASSERT
(
fixed
==
1
);
if
(
null_value
)
if
(
null_value
)
...
@@ -2336,9 +2336,9 @@ Item_sum_hybrid::get_date(MYSQL_TIME *ltime, ulonglong fuzzydate)
...
@@ -2336,9 +2336,9 @@ Item_sum_hybrid::get_date(MYSQL_TIME *ltime, ulonglong fuzzydate)
}
}
void
Item_sum_
hybrid
::
direct_add
(
Item
*
item
)
void
Item_sum_
min_max
::
direct_add
(
Item
*
item
)
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::direct_add"
);
DBUG_ENTER
(
"Item_sum_
min_max
::direct_add"
);
DBUG_PRINT
(
"info"
,
(
"item: %p"
,
item
));
DBUG_PRINT
(
"info"
,
(
"item: %p"
,
item
));
direct_added
=
TRUE
;
direct_added
=
TRUE
;
direct_item
=
item
;
direct_item
=
item
;
...
@@ -2346,9 +2346,9 @@ void Item_sum_hybrid::direct_add(Item *item)
...
@@ -2346,9 +2346,9 @@ void Item_sum_hybrid::direct_add(Item *item)
}
}
double
Item_sum_
hybrid
::
val_real
()
double
Item_sum_
min_max
::
val_real
()
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::val_real"
);
DBUG_ENTER
(
"Item_sum_
min_max
::val_real"
);
DBUG_ASSERT
(
fixed
==
1
);
DBUG_ASSERT
(
fixed
==
1
);
if
(
null_value
)
if
(
null_value
)
DBUG_RETURN
(
0.0
);
DBUG_RETURN
(
0.0
);
...
@@ -2358,9 +2358,9 @@ double Item_sum_hybrid::val_real()
...
@@ -2358,9 +2358,9 @@ double Item_sum_hybrid::val_real()
DBUG_RETURN
(
retval
);
DBUG_RETURN
(
retval
);
}
}
longlong
Item_sum_
hybrid
::
val_int
()
longlong
Item_sum_
min_max
::
val_int
()
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::val_int"
);
DBUG_ENTER
(
"Item_sum_
min_max
::val_int"
);
DBUG_ASSERT
(
fixed
==
1
);
DBUG_ASSERT
(
fixed
==
1
);
if
(
null_value
)
if
(
null_value
)
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
...
@@ -2371,9 +2371,9 @@ longlong Item_sum_hybrid::val_int()
...
@@ -2371,9 +2371,9 @@ longlong Item_sum_hybrid::val_int()
}
}
my_decimal
*
Item_sum_
hybrid
::
val_decimal
(
my_decimal
*
val
)
my_decimal
*
Item_sum_
min_max
::
val_decimal
(
my_decimal
*
val
)
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::val_decimal"
);
DBUG_ENTER
(
"Item_sum_
min_max
::val_decimal"
);
DBUG_ASSERT
(
fixed
==
1
);
DBUG_ASSERT
(
fixed
==
1
);
if
(
null_value
)
if
(
null_value
)
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
...
@@ -2385,9 +2385,9 @@ my_decimal *Item_sum_hybrid::val_decimal(my_decimal *val)
...
@@ -2385,9 +2385,9 @@ my_decimal *Item_sum_hybrid::val_decimal(my_decimal *val)
String
*
String
*
Item_sum_
hybrid
::
val_str
(
String
*
str
)
Item_sum_
min_max
::
val_str
(
String
*
str
)
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::val_str"
);
DBUG_ENTER
(
"Item_sum_
min_max
::val_str"
);
DBUG_ASSERT
(
fixed
==
1
);
DBUG_ASSERT
(
fixed
==
1
);
if
(
null_value
)
if
(
null_value
)
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
...
@@ -2398,9 +2398,9 @@ Item_sum_hybrid::val_str(String *str)
...
@@ -2398,9 +2398,9 @@ Item_sum_hybrid::val_str(String *str)
}
}
void
Item_sum_
hybrid
::
cleanup
()
void
Item_sum_
min_max
::
cleanup
()
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::cleanup"
);
DBUG_ENTER
(
"Item_sum_
min_max
::cleanup"
);
Item_sum
::
cleanup
();
Item_sum
::
cleanup
();
if
(
cmp
)
if
(
cmp
)
delete
cmp
;
delete
cmp
;
...
@@ -2416,9 +2416,9 @@ void Item_sum_hybrid::cleanup()
...
@@ -2416,9 +2416,9 @@ void Item_sum_hybrid::cleanup()
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
void
Item_sum_
hybrid
::
no_rows_in_result
()
void
Item_sum_
min_max
::
no_rows_in_result
()
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::no_rows_in_result"
);
DBUG_ENTER
(
"Item_sum_
min_max
::no_rows_in_result"
);
/* We may be called here twice in case of ref field in function */
/* We may be called here twice in case of ref field in function */
if
(
was_values
)
if
(
was_values
)
{
{
...
@@ -2429,7 +2429,7 @@ void Item_sum_hybrid::no_rows_in_result()
...
@@ -2429,7 +2429,7 @@ void Item_sum_hybrid::no_rows_in_result()
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
void
Item_sum_
hybrid
::
restore_to_before_no_rows_in_result
()
void
Item_sum_
min_max
::
restore_to_before_no_rows_in_result
()
{
{
if
(
!
was_values
)
if
(
!
was_values
)
{
{
...
@@ -2693,10 +2693,10 @@ void Item_sum_num::reset_field()
...
@@ -2693,10 +2693,10 @@ void Item_sum_num::reset_field()
}
}
void
Item_sum_
hybrid
::
reset_field
()
void
Item_sum_
min_max
::
reset_field
()
{
{
Item
*
UNINIT_VAR
(
tmp_item
),
*
arg0
;
Item
*
UNINIT_VAR
(
tmp_item
),
*
arg0
;
DBUG_ENTER
(
"Item_sum_
hybrid
::reset_field"
);
DBUG_ENTER
(
"Item_sum_
min_max
::reset_field"
);
arg0
=
args
[
0
];
arg0
=
args
[
0
];
if
(
unlikely
(
direct_added
))
if
(
unlikely
(
direct_added
))
...
@@ -3049,9 +3049,9 @@ Item *Item_sum_avg::result_item(THD *thd, Field *field)
...
@@ -3049,9 +3049,9 @@ Item *Item_sum_avg::result_item(THD *thd, Field *field)
}
}
void
Item_sum_
hybrid
::
update_field
()
void
Item_sum_
min_max
::
update_field
()
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::update_field"
);
DBUG_ENTER
(
"Item_sum_
min_max
::update_field"
);
Item
*
UNINIT_VAR
(
tmp_item
);
Item
*
UNINIT_VAR
(
tmp_item
);
if
(
unlikely
(
direct_added
))
if
(
unlikely
(
direct_added
))
{
{
...
@@ -3081,9 +3081,9 @@ void Item_sum_hybrid::update_field()
...
@@ -3081,9 +3081,9 @@ void Item_sum_hybrid::update_field()
void
void
Item_sum_
hybrid
::
min_max_update_str_field
()
Item_sum_
min_max
::
min_max_update_str_field
()
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::min_max_update_str_field"
);
DBUG_ENTER
(
"Item_sum_
min_max
::min_max_update_str_field"
);
DBUG_ASSERT
(
cmp
);
DBUG_ASSERT
(
cmp
);
String
*
res_str
=
args
[
0
]
->
val_str
(
&
cmp
->
value1
);
String
*
res_str
=
args
[
0
]
->
val_str
(
&
cmp
->
value1
);
...
@@ -3104,11 +3104,11 @@ Item_sum_hybrid::min_max_update_str_field()
...
@@ -3104,11 +3104,11 @@ Item_sum_hybrid::min_max_update_str_field()
void
void
Item_sum_
hybrid
::
min_max_update_real_field
()
Item_sum_
min_max
::
min_max_update_real_field
()
{
{
double
nr
,
old_nr
;
double
nr
,
old_nr
;
DBUG_ENTER
(
"Item_sum_
hybrid
::min_max_update_real_field"
);
DBUG_ENTER
(
"Item_sum_
min_max
::min_max_update_real_field"
);
old_nr
=
result_field
->
val_real
();
old_nr
=
result_field
->
val_real
();
nr
=
args
[
0
]
->
val_real
();
nr
=
args
[
0
]
->
val_real
();
if
(
!
args
[
0
]
->
null_value
)
if
(
!
args
[
0
]
->
null_value
)
...
@@ -3126,11 +3126,11 @@ Item_sum_hybrid::min_max_update_real_field()
...
@@ -3126,11 +3126,11 @@ Item_sum_hybrid::min_max_update_real_field()
void
void
Item_sum_
hybrid
::
min_max_update_int_field
()
Item_sum_
min_max
::
min_max_update_int_field
()
{
{
longlong
nr
,
old_nr
;
longlong
nr
,
old_nr
;
DBUG_ENTER
(
"Item_sum_
hybrid
::min_max_update_int_field"
);
DBUG_ENTER
(
"Item_sum_
min_max
::min_max_update_int_field"
);
old_nr
=
result_field
->
val_int
();
old_nr
=
result_field
->
val_int
();
nr
=
args
[
0
]
->
val_int
();
nr
=
args
[
0
]
->
val_int
();
if
(
!
args
[
0
]
->
null_value
)
if
(
!
args
[
0
]
->
null_value
)
...
@@ -3161,9 +3161,9 @@ Item_sum_hybrid::min_max_update_int_field()
...
@@ -3161,9 +3161,9 @@ Item_sum_hybrid::min_max_update_int_field()
optimize: do not get result_field in case of args[0] is NULL
optimize: do not get result_field in case of args[0] is NULL
*/
*/
void
void
Item_sum_
hybrid
::
min_max_update_decimal_field
()
Item_sum_
min_max
::
min_max_update_decimal_field
()
{
{
DBUG_ENTER
(
"Item_sum_
hybrid
::min_max_update_decimal_field"
);
DBUG_ENTER
(
"Item_sum_
min_max
::min_max_update_decimal_field"
);
my_decimal
old_val
,
nr_val
;
my_decimal
old_val
,
nr_val
;
const
my_decimal
*
old_nr
;
const
my_decimal
*
old_nr
;
const
my_decimal
*
nr
=
args
[
0
]
->
val_decimal
(
&
nr_val
);
const
my_decimal
*
nr
=
args
[
0
]
->
val_decimal
(
&
nr_val
);
...
...
sql/item_sum.h
View file @
e978efd9
...
@@ -1025,10 +1025,32 @@ class Item_sum_std :public Item_sum_variance
...
@@ -1025,10 +1025,32 @@ class Item_sum_std :public Item_sum_variance
{
return
get_item_copy
<
Item_sum_std
>
(
thd
,
this
);
}
{
return
get_item_copy
<
Item_sum_std
>
(
thd
,
this
);
}
};
};
class
Item_sum_hybrid
:
public
Item_sum
,
public
Type_handler_hybrid_field_type
{
public:
Item_sum_hybrid
(
THD
*
thd
,
Item
*
item_par
)
:
Item_sum
(
thd
,
item_par
),
Type_handler_hybrid_field_type
(
&
type_handler_longlong
)
{
collation
.
set
(
&
my_charset_bin
);
}
Item_sum_hybrid
(
THD
*
thd
,
Item
*
a
,
Item
*
b
)
:
Item_sum
(
thd
,
a
,
b
),
Type_handler_hybrid_field_type
(
&
type_handler_longlong
)
{
collation
.
set
(
&
my_charset_bin
);
}
Item_sum_hybrid
(
THD
*
thd
,
Item_sum_hybrid
*
item
)
:
Item_sum
(
thd
,
item
),
Type_handler_hybrid_field_type
(
item
)
{
}
const
Type_handler
*
type_handler
()
const
{
return
Type_handler_hybrid_field_type
::
type_handler
();
}
};
// This class is a string or number function depending on num_func
// This class is a string or number function depending on num_func
class
Arg_comparator
;
class
Arg_comparator
;
class
Item_cache
;
class
Item_cache
;
class
Item_sum_
hybrid
:
public
Item_sum
,
public
Type_handler_hybrid_field_type
class
Item_sum_
min_max
:
public
Item_sum_hybrid
{
{
protected:
protected:
bool
direct_added
;
bool
direct_added
;
...
@@ -1039,16 +1061,14 @@ class Item_sum_hybrid :public Item_sum, public Type_handler_hybrid_field_type
...
@@ -1039,16 +1061,14 @@ class Item_sum_hybrid :public Item_sum, public Type_handler_hybrid_field_type
bool
was_values
;
// Set if we have found at least one row (for max/min only)
bool
was_values
;
// Set if we have found at least one row (for max/min only)
bool
was_null_value
;
bool
was_null_value
;
public:
public:
Item_sum_hybrid
(
THD
*
thd
,
Item
*
item_par
,
int
sign
)
:
Item_sum_min_max
(
THD
*
thd
,
Item
*
item_par
,
int
sign
)
:
Item_sum
(
thd
,
item_par
),
Item_sum_hybrid
(
thd
,
item_par
),
Type_handler_hybrid_field_type
(
&
type_handler_longlong
),
direct_added
(
FALSE
),
value
(
0
),
arg_cache
(
0
),
cmp
(
0
),
direct_added
(
FALSE
),
value
(
0
),
arg_cache
(
0
),
cmp
(
0
),
cmp_sign
(
sign
),
was_values
(
TRUE
)
cmp_sign
(
sign
),
was_values
(
TRUE
)
{
collation
.
set
(
&
my_charset_bin
);
}
{
collation
.
set
(
&
my_charset_bin
);
}
Item_sum_hybrid
(
THD
*
thd
,
Item_sum_hybrid
*
item
)
Item_sum_min_max
(
THD
*
thd
,
Item_sum_min_max
*
item
)
:
Item_sum
(
thd
,
item
),
:
Item_sum_hybrid
(
thd
,
item
),
Type_handler_hybrid_field_type
(
item
),
direct_added
(
FALSE
),
value
(
item
->
value
),
arg_cache
(
0
),
direct_added
(
FALSE
),
value
(
item
->
value
),
arg_cache
(
0
),
cmp_sign
(
item
->
cmp_sign
),
was_values
(
item
->
was_values
)
cmp_sign
(
item
->
cmp_sign
),
was_values
(
item
->
was_values
)
{
}
{
}
...
@@ -1067,8 +1087,6 @@ class Item_sum_hybrid :public Item_sum, public Type_handler_hybrid_field_type
...
@@ -1067,8 +1087,6 @@ class Item_sum_hybrid :public Item_sum, public Type_handler_hybrid_field_type
{
{
return
get_arg
(
0
)
->
real_type_handler
();
return
get_arg
(
0
)
->
real_type_handler
();
}
}
const
Type_handler
*
type_handler
()
const
{
return
Type_handler_hybrid_field_type
::
type_handler
();
}
TYPELIB
*
get_typelib
()
const
{
return
args
[
0
]
->
get_typelib
();
}
TYPELIB
*
get_typelib
()
const
{
return
args
[
0
]
->
get_typelib
();
}
void
update_field
();
void
update_field
();
void
min_max_update_str_field
();
void
min_max_update_str_field
();
...
@@ -1084,11 +1102,11 @@ class Item_sum_hybrid :public Item_sum, public Type_handler_hybrid_field_type
...
@@ -1084,11 +1102,11 @@ class Item_sum_hybrid :public Item_sum, public Type_handler_hybrid_field_type
};
};
class
Item_sum_min
:
public
Item_sum_
hybrid
class
Item_sum_min
:
public
Item_sum_
min_max
{
{
public:
public:
Item_sum_min
(
THD
*
thd
,
Item
*
item_par
)
:
Item_sum_
hybrid
(
thd
,
item_par
,
1
)
{}
Item_sum_min
(
THD
*
thd
,
Item
*
item_par
)
:
Item_sum_
min_max
(
thd
,
item_par
,
1
)
{}
Item_sum_min
(
THD
*
thd
,
Item_sum_min
*
item
)
:
Item_sum_
hybrid
(
thd
,
item
)
{}
Item_sum_min
(
THD
*
thd
,
Item_sum_min
*
item
)
:
Item_sum_
min_max
(
thd
,
item
)
{}
enum
Sumfunctype
sum_func
()
const
{
return
MIN_FUNC
;}
enum
Sumfunctype
sum_func
()
const
{
return
MIN_FUNC
;}
bool
add
();
bool
add
();
...
@@ -1099,11 +1117,11 @@ class Item_sum_min :public Item_sum_hybrid
...
@@ -1099,11 +1117,11 @@ class Item_sum_min :public Item_sum_hybrid
};
};
class
Item_sum_max
:
public
Item_sum_
hybrid
class
Item_sum_max
:
public
Item_sum_
min_max
{
{
public:
public:
Item_sum_max
(
THD
*
thd
,
Item
*
item_par
)
:
Item_sum_
hybrid
(
thd
,
item_par
,
-
1
)
{}
Item_sum_max
(
THD
*
thd
,
Item
*
item_par
)
:
Item_sum_
min_max
(
thd
,
item_par
,
-
1
)
{}
Item_sum_max
(
THD
*
thd
,
Item_sum_max
*
item
)
:
Item_sum_
hybrid
(
thd
,
item
)
{}
Item_sum_max
(
THD
*
thd
,
Item_sum_max
*
item
)
:
Item_sum_
min_max
(
thd
,
item
)
{}
enum
Sumfunctype
sum_func
()
const
{
return
MAX_FUNC
;}
enum
Sumfunctype
sum_func
()
const
{
return
MAX_FUNC
;}
bool
add
();
bool
add
();
...
...
sql/item_windowfunc.h
View file @
e978efd9
...
@@ -292,21 +292,18 @@ class Item_sum_dense_rank: public Item_sum_int
...
@@ -292,21 +292,18 @@ class Item_sum_dense_rank: public Item_sum_int
{
return
get_item_copy
<
Item_sum_dense_rank
>
(
thd
,
this
);
}
{
return
get_item_copy
<
Item_sum_dense_rank
>
(
thd
,
this
);
}
};
};
class
Item_sum_hybrid_simple
:
public
Item_sum
,
class
Item_sum_hybrid_simple
:
public
Item_sum_hybrid
public
Type_handler_hybrid_field_type
{
{
public:
public:
Item_sum_hybrid_simple
(
THD
*
thd
,
Item
*
arg
)
:
Item_sum_hybrid_simple
(
THD
*
thd
,
Item
*
arg
)
:
Item_sum
(
thd
,
arg
),
Item_sum_hybrid
(
thd
,
arg
),
Type_handler_hybrid_field_type
(
&
type_handler_longlong
),
value
(
NULL
)
value
(
NULL
)
{
collation
.
set
(
&
my_charset_bin
);
}
{
}
Item_sum_hybrid_simple
(
THD
*
thd
,
Item
*
arg1
,
Item
*
arg2
)
:
Item_sum_hybrid_simple
(
THD
*
thd
,
Item
*
arg1
,
Item
*
arg2
)
:
Item_sum
(
thd
,
arg1
,
arg2
),
Item_sum_hybrid
(
thd
,
arg1
,
arg2
),
Type_handler_hybrid_field_type
(
&
type_handler_longlong
),
value
(
NULL
)
value
(
NULL
)
{
collation
.
set
(
&
my_charset_bin
);
}
{
}
bool
add
();
bool
add
();
bool
fix_fields
(
THD
*
,
Item
**
);
bool
fix_fields
(
THD
*
,
Item
**
);
...
@@ -317,8 +314,6 @@ class Item_sum_hybrid_simple : public Item_sum,
...
@@ -317,8 +314,6 @@ class Item_sum_hybrid_simple : public Item_sum,
void
reset_field
();
void
reset_field
();
String
*
val_str
(
String
*
);
String
*
val_str
(
String
*
);
bool
get_date
(
MYSQL_TIME
*
ltime
,
ulonglong
fuzzydate
);
bool
get_date
(
MYSQL_TIME
*
ltime
,
ulonglong
fuzzydate
);
const
Type_handler
*
type_handler
()
const
{
return
Type_handler_hybrid_field_type
::
type_handler
();
}
void
update_field
();
void
update_field
();
Field
*
create_tmp_field
(
bool
group
,
TABLE
*
table
);
Field
*
create_tmp_field
(
bool
group
,
TABLE
*
table
);
void
clear
()
void
clear
()
...
...
sql/sql_type.cc
View file @
e978efd9
...
@@ -365,7 +365,7 @@ Type_handler::blob_type_handler(const Item *item)
...
@@ -365,7 +365,7 @@ Type_handler::blob_type_handler(const Item *item)
/**
/**
This method is used by:
This method is used by:
- Item_sum_
hybrid
, e.g. MAX(item), MIN(item).
- Item_sum_
min_max
, e.g. MAX(item), MIN(item).
- Item_func_set_user_var
- Item_func_set_user_var
*/
*/
const
Type_handler
*
const
Type_handler
*
...
@@ -3086,9 +3086,9 @@ bool Type_handler_real_result::
...
@@ -3086,9 +3086,9 @@ bool Type_handler_real_result::
QQ: Items should probably be fixed to preserve the exact type.
QQ: Items should probably be fixed to preserve the exact type.
*/
*/
bool
Type_handler_numeric
::
bool
Type_handler_numeric
::
Item_sum_
hybrid_fix_length_and_dec_numeric
(
Item_sum_hybrid
*
func
,
Item_sum_
min_max_fix_length_and_dec_numeric
(
Item_sum_min_max
*
func
,
const
Type_handler
*
handler
)
const
Type_handler
*
handler
)
const
const
{
{
Item
*
item
=
func
->
arguments
()[
0
];
Item
*
item
=
func
->
arguments
()[
0
];
Item
*
item2
=
item
->
real_item
();
Item
*
item2
=
item
->
real_item
();
...
@@ -3104,28 +3104,28 @@ bool Type_handler_numeric::
...
@@ -3104,28 +3104,28 @@ bool Type_handler_numeric::
bool
Type_handler_int_result
::
bool
Type_handler_int_result
::
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
{
{
return
Item_sum_
hybrid
_fix_length_and_dec_numeric
(
func
,
return
Item_sum_
min_max
_fix_length_and_dec_numeric
(
func
,
&
type_handler_longlong
);
&
type_handler_longlong
);
}
}
bool
Type_handler_real_result
::
bool
Type_handler_real_result
::
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
{
{
(
void
)
Item_sum_
hybrid
_fix_length_and_dec_numeric
(
func
,
(
void
)
Item_sum_
min_max
_fix_length_and_dec_numeric
(
func
,
&
type_handler_double
);
&
type_handler_double
);
func
->
max_length
=
func
->
float_length
(
func
->
decimals
);
func
->
max_length
=
func
->
float_length
(
func
->
decimals
);
return
false
;
return
false
;
}
}
bool
Type_handler_decimal_result
::
bool
Type_handler_decimal_result
::
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
{
{
return
Item_sum_
hybrid
_fix_length_and_dec_numeric
(
func
,
return
Item_sum_
min_max
_fix_length_and_dec_numeric
(
func
,
&
type_handler_newdecimal
);
&
type_handler_newdecimal
);
}
}
...
@@ -3138,7 +3138,7 @@ bool Type_handler_decimal_result::
...
@@ -3138,7 +3138,7 @@ bool Type_handler_decimal_result::
MAX(str_item) chooses the best suitable string type.
MAX(str_item) chooses the best suitable string type.
*/
*/
bool
Type_handler_string_result
::
bool
Type_handler_string_result
::
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
{
{
Item
*
item
=
func
->
arguments
()[
0
];
Item
*
item
=
func
->
arguments
()[
0
];
Item
*
item2
=
item
->
real_item
();
Item
*
item2
=
item
->
real_item
();
...
@@ -3164,7 +3164,7 @@ bool Type_handler_string_result::
...
@@ -3164,7 +3164,7 @@ bool Type_handler_string_result::
Traditional temporal types always preserve the type of the argument.
Traditional temporal types always preserve the type of the argument.
*/
*/
bool
Type_handler_temporal_result
::
bool
Type_handler_temporal_result
::
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
{
{
Item
*
item
=
func
->
arguments
()[
0
];
Item
*
item
=
func
->
arguments
()[
0
];
func
->
Type_std_attributes
::
set
(
item
);
func
->
Type_std_attributes
::
set
(
item
);
...
...
sql/sql_type.h
View file @
e978efd9
...
@@ -33,7 +33,7 @@ class Item;
...
@@ -33,7 +33,7 @@ class Item;
class
Item_param
;
class
Item_param
;
class
Item_cache
;
class
Item_cache
;
class
Item_func_or_sum
;
class
Item_func_or_sum
;
class
Item_sum_
hybrid
;
class
Item_sum_
min_max
;
class
Item_sum_sum
;
class
Item_sum_sum
;
class
Item_sum_avg
;
class
Item_sum_avg
;
class
Item_sum_variance
;
class
Item_sum_variance
;
...
@@ -1314,7 +1314,7 @@ class Type_handler
...
@@ -1314,7 +1314,7 @@ class Type_handler
Item_func_min_max
*
func
,
Item_func_min_max
*
func
,
Item
**
items
,
Item
**
items
,
uint
nitems
)
const
;
uint
nitems
)
const
;
virtual
bool
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
)
const
=
0
;
virtual
bool
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
)
const
=
0
;
virtual
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
=
0
;
virtual
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
=
0
;
virtual
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
=
0
;
virtual
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
=
0
;
virtual
virtual
...
@@ -1563,7 +1563,7 @@ class Type_handler_row: public Type_handler
...
@@ -1563,7 +1563,7 @@ class Type_handler_row: public Type_handler
DBUG_ASSERT
(
0
);
DBUG_ASSERT
(
0
);
return
true
;
return
true
;
}
}
bool
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
bool
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
{
{
DBUG_ASSERT
(
0
);
DBUG_ASSERT
(
0
);
return
true
;
return
true
;
...
@@ -1743,9 +1743,9 @@ class Type_handler_row: public Type_handler
...
@@ -1743,9 +1743,9 @@ class Type_handler_row: public Type_handler
class
Type_handler_numeric
:
public
Type_handler
class
Type_handler_numeric
:
public
Type_handler
{
{
protected:
protected:
bool
Item_sum_
hybrid_fix_length_and_dec_numeric
(
Item_sum_hybrid
*
func
,
bool
Item_sum_
min_max_fix_length_and_dec_numeric
(
Item_sum_min_max
*
func
,
const
Type_handler
*
handler
)
const
Type_handler
*
handler
)
const
;
const
;
public:
public:
String
*
print_item_value
(
THD
*
thd
,
Item
*
item
,
String
*
str
)
const
;
String
*
print_item_value
(
THD
*
thd
,
Item
*
item
,
String
*
str
)
const
;
double
Item_func_min_max_val_real
(
Item_func_min_max
*
)
const
;
double
Item_func_min_max_val_real
(
Item_func_min_max
*
)
const
;
...
@@ -1796,7 +1796,7 @@ class Type_handler_real_result: public Type_handler_numeric
...
@@ -1796,7 +1796,7 @@ class Type_handler_real_result: public Type_handler_numeric
Item
**
items
,
uint
nitems
)
const
;
Item
**
items
,
uint
nitems
)
const
;
bool
Item_func_min_max_fix_attributes
(
THD
*
thd
,
Item_func_min_max
*
func
,
bool
Item_func_min_max_fix_attributes
(
THD
*
thd
,
Item_func_min_max
*
func
,
Item
**
items
,
uint
nitems
)
const
;
Item
**
items
,
uint
nitems
)
const
;
bool
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
;
bool
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
...
@@ -1874,7 +1874,7 @@ class Type_handler_decimal_result: public Type_handler_numeric
...
@@ -1874,7 +1874,7 @@ class Type_handler_decimal_result: public Type_handler_numeric
Type_handler_hybrid_field_type
*
,
Type_handler_hybrid_field_type
*
,
Type_all_attributes
*
atrr
,
Type_all_attributes
*
atrr
,
Item
**
items
,
uint
nitems
)
const
;
Item
**
items
,
uint
nitems
)
const
;
bool
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
;
bool
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
...
@@ -2068,7 +2068,7 @@ class Type_handler_int_result: public Type_handler_numeric
...
@@ -2068,7 +2068,7 @@ class Type_handler_int_result: public Type_handler_numeric
Type_handler_hybrid_field_type
*
,
Type_handler_hybrid_field_type
*
,
Type_all_attributes
*
atrr
,
Type_all_attributes
*
atrr
,
Item
**
items
,
uint
nitems
)
const
;
Item
**
items
,
uint
nitems
)
const
;
bool
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
;
bool
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
...
@@ -2145,7 +2145,7 @@ class Type_handler_temporal_result: public Type_handler
...
@@ -2145,7 +2145,7 @@ class Type_handler_temporal_result: public Type_handler
const
Item
*
outer
)
const
;
const
Item
*
outer
)
const
;
bool
Item_func_min_max_fix_attributes
(
THD
*
thd
,
Item_func_min_max
*
func
,
bool
Item_func_min_max_fix_attributes
(
THD
*
thd
,
Item_func_min_max
*
func
,
Item
**
items
,
uint
nitems
)
const
;
Item
**
items
,
uint
nitems
)
const
;
bool
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
;
bool
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
...
@@ -2258,7 +2258,7 @@ class Type_handler_string_result: public Type_handler
...
@@ -2258,7 +2258,7 @@ class Type_handler_string_result: public Type_handler
Type_handler_hybrid_field_type
*
,
Type_handler_hybrid_field_type
*
,
Type_all_attributes
*
atrr
,
Type_all_attributes
*
atrr
,
Item
**
items
,
uint
nitems
)
const
;
Item
**
items
,
uint
nitems
)
const
;
bool
Item_sum_
hybrid_fix_length_and_dec
(
Item_sum_hybrid
*
func
)
const
;
bool
Item_sum_
min_max_fix_length_and_dec
(
Item_sum_min_max
*
func
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_sum_fix_length_and_dec
(
Item_sum_sum
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_avg_fix_length_and_dec
(
Item_sum_avg
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
bool
Item_sum_variance_fix_length_and_dec
(
Item_sum_variance
*
)
const
;
...
...
storage/spider/spd_db_conn.cc
View file @
e978efd9
...
@@ -2705,7 +2705,7 @@ int spider_db_fetch_for_item_sum_func(
...
@@ -2705,7 +2705,7 @@ int spider_db_fetch_for_item_sum_func(
thd
->
free_list
=
free_list
;
thd
->
free_list
=
free_list
;
}
}
Item_sum_
hybrid
*
item_hybrid
=
(
Item_sum_hybrid
*
)
item_sum
;
Item_sum_
min_max
*
item_sum_min_max
=
(
Item_sum_min_max
*
)
item_sum
;
Item_string
*
item
=
Item_string
*
item
=
(
Item_string
*
)
spider
->
direct_aggregate_item_current
->
item
;
(
Item_string
*
)
spider
->
direct_aggregate_item_current
->
item
;
if
(
row
->
is_null
())
if
(
row
->
is_null
())
...
@@ -2732,7 +2732,7 @@ int spider_db_fetch_for_item_sum_func(
...
@@ -2732,7 +2732,7 @@ int spider_db_fetch_for_item_sum_func(
#endif
#endif
item
->
null_value
=
FALSE
;
item
->
null_value
=
FALSE
;
}
}
item_
hybrid
->
direct_add
(
item
);
item_
sum_min_max
->
direct_add
(
item
);
row
->
next
();
row
->
next
();
}
}
break
;
break
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment