2017-06-18 06:25:01 +03:00
|
|
|
/*
|
2020-07-14 17:13:37 +03:00
|
|
|
Copyright (c) 2016, 2020, MariaDB
|
2017-06-18 06:25:01 +03: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; version 2 of the License.
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
|
|
|
|
|
2016-02-12 20:33:56 -08:00
|
|
|
#ifndef ITEM_WINDOWFUNC_INCLUDED
|
|
|
|
#define ITEM_WINDOWFUNC_INCLUDED
|
|
|
|
|
|
|
|
#include "item.h"
|
|
|
|
|
|
|
|
class Window_spec;
|
|
|
|
|
2016-03-24 02:09:17 +03:00
|
|
|
|
|
|
|
int test_if_group_changed(List<Cached_item> &list);
|
|
|
|
|
2017-06-27 02:50:18 +05:30
|
|
|
|
2016-03-24 02:09:17 +03:00
|
|
|
/* A wrapper around test_if_group_changed */
|
|
|
|
class Group_bound_tracker
|
|
|
|
{
|
|
|
|
public:
|
2016-09-01 18:10:15 +03:00
|
|
|
|
|
|
|
Group_bound_tracker(THD *thd, SQL_I_List<ORDER> *list)
|
2016-03-24 02:09:17 +03:00
|
|
|
{
|
2017-07-18 01:55:31 +05:30
|
|
|
for (ORDER *curr = list->first; curr; curr=curr->next)
|
2016-03-24 02:09:17 +03:00
|
|
|
{
|
2017-06-27 02:50:18 +05:30
|
|
|
Cached_item *tmp= new_Cached_item(thd, curr->item[0], TRUE);
|
|
|
|
group_fields.push_back(tmp);
|
2016-03-24 02:09:17 +03:00
|
|
|
}
|
2016-09-01 18:10:15 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
void init()
|
|
|
|
{
|
2016-04-10 07:51:42 +03:00
|
|
|
first_check= true;
|
2016-03-24 02:09:17 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
Check if the current row is in a different group than the previous row
|
|
|
|
this function was called for.
|
2016-04-10 07:51:42 +03:00
|
|
|
XXX: Side-effect: The new row's group becomes the current row's group.
|
|
|
|
|
|
|
|
Returns true if there is a change between the current_group and the cached
|
|
|
|
value, or if it is the first check after a call to init.
|
2016-03-24 02:09:17 +03:00
|
|
|
*/
|
|
|
|
bool check_if_next_group()
|
|
|
|
{
|
2016-04-10 07:51:42 +03:00
|
|
|
if (test_if_group_changed(group_fields) > -1 || first_check)
|
|
|
|
{
|
|
|
|
first_check= false;
|
2016-03-24 02:09:17 +03:00
|
|
|
return true;
|
2016-04-10 07:51:42 +03:00
|
|
|
}
|
2016-03-24 02:09:17 +03:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-04-10 07:51:42 +03:00
|
|
|
/*
|
|
|
|
Check if the current row is in a different group than the previous row
|
|
|
|
check_if_next_group was called for.
|
|
|
|
|
|
|
|
Compares the groups without the additional side effect of updating the
|
|
|
|
current cached values.
|
|
|
|
*/
|
2016-03-24 02:09:17 +03:00
|
|
|
int compare_with_cache()
|
|
|
|
{
|
|
|
|
List_iterator<Cached_item> li(group_fields);
|
|
|
|
Cached_item *ptr;
|
|
|
|
int res;
|
|
|
|
while ((ptr= li++))
|
|
|
|
{
|
|
|
|
if ((res= ptr->cmp_read_only()))
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
2019-06-04 12:41:52 +05:30
|
|
|
~Group_bound_tracker()
|
|
|
|
{
|
|
|
|
group_fields.delete_elements();
|
|
|
|
}
|
2016-09-01 18:10:15 +03:00
|
|
|
|
|
|
|
private:
|
|
|
|
List<Cached_item> group_fields;
|
|
|
|
/*
|
|
|
|
During the first check_if_next_group, the list of cached_items is not
|
|
|
|
initialized. The compare function will return that the items match if
|
|
|
|
the field's value is the same as the Cached_item's default value (0).
|
|
|
|
This flag makes sure that we always return true during the first check.
|
|
|
|
|
|
|
|
XXX This is better to be implemented within test_if_group_changed, but
|
|
|
|
since it is used in other parts of the codebase, we keep it here for now.
|
|
|
|
*/
|
|
|
|
bool first_check;
|
2016-03-24 02:09:17 +03:00
|
|
|
};
|
|
|
|
|
2016-02-05 16:50:50 +03:00
|
|
|
/*
|
|
|
|
ROW_NUMBER() OVER (...)
|
|
|
|
|
2016-02-06 01:53:17 +03:00
|
|
|
@detail
|
2016-02-05 16:50:50 +03:00
|
|
|
- This is a Window function (not just an aggregate)
|
|
|
|
- It can be computed by doing one pass over select output, provided
|
|
|
|
the output is sorted according to the window definition.
|
|
|
|
*/
|
2016-02-12 20:33:56 -08:00
|
|
|
|
|
|
|
class Item_sum_row_number: public Item_sum_int
|
|
|
|
{
|
|
|
|
longlong count;
|
|
|
|
|
2016-02-14 21:00:05 +03:00
|
|
|
public:
|
2016-09-01 18:10:15 +03:00
|
|
|
|
|
|
|
Item_sum_row_number(THD *thd)
|
|
|
|
: Item_sum_int(thd), count(0) {}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
const Type_handler *type_handler() const override
|
|
|
|
{ return &type_handler_slonglong; }
|
2019-08-15 13:16:00 +04:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void clear() override
|
2016-02-14 21:00:05 +03:00
|
|
|
{
|
|
|
|
count= 0;
|
|
|
|
}
|
2016-09-01 18:10:15 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool add() override
|
2016-02-14 21:00:05 +03:00
|
|
|
{
|
|
|
|
count++;
|
2016-09-01 18:10:15 +03:00
|
|
|
return false;
|
2016-02-14 21:00:05 +03:00
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void reset_field() override { DBUG_ASSERT(0); }
|
|
|
|
void update_field() override {}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func() const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
|
|
|
return ROW_NUMBER_FUNC;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
longlong val_int() override
|
2016-02-14 21:00:05 +03:00
|
|
|
{
|
|
|
|
return count;
|
|
|
|
}
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("row_number") };
|
|
|
|
return name;
|
2016-02-12 20:33:56 -08:00
|
|
|
}
|
2016-09-01 18:10:15 +03:00
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_row_number>(thd, this); }
|
2016-02-12 20:33:56 -08:00
|
|
|
};
|
|
|
|
|
2016-02-05 16:50:50 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
RANK() OVER (...) Windowing function
|
|
|
|
|
2016-02-06 01:53:17 +03:00
|
|
|
@detail
|
2016-02-05 16:50:50 +03:00
|
|
|
- This is a Window function (not just an aggregate)
|
|
|
|
- It can be computed by doing one pass over select output, provided
|
|
|
|
the output is sorted according to the window definition.
|
2016-02-06 01:53:17 +03:00
|
|
|
|
|
|
|
The function is defined as:
|
|
|
|
|
|
|
|
"The rank of row R is defined as 1 (one) plus the number of rows that
|
|
|
|
precede R and are not peers of R"
|
|
|
|
|
|
|
|
"This implies that if two or more rows are not distinct with respect to
|
|
|
|
the window ordering, then there will be one or more"
|
2016-02-05 16:50:50 +03:00
|
|
|
*/
|
|
|
|
|
2016-02-12 20:33:56 -08:00
|
|
|
class Item_sum_rank: public Item_sum_int
|
|
|
|
{
|
2016-03-03 18:45:37 +02:00
|
|
|
protected:
|
2016-02-06 01:53:17 +03:00
|
|
|
longlong row_number; // just ROW_NUMBER()
|
|
|
|
longlong cur_rank; // current value
|
2016-09-01 18:10:15 +03:00
|
|
|
|
|
|
|
Group_bound_tracker *peer_tracker;
|
2016-02-06 01:53:17 +03:00
|
|
|
public:
|
2016-09-01 18:10:15 +03:00
|
|
|
|
|
|
|
Item_sum_rank(THD *thd) : Item_sum_int(thd), peer_tracker(NULL) {}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
const Type_handler *type_handler() const override
|
|
|
|
{ return &type_handler_slonglong; }
|
2019-08-15 13:16:00 +04:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void clear() override
|
2016-02-05 16:50:50 +03:00
|
|
|
{
|
2016-02-06 01:53:17 +03:00
|
|
|
/* This is called on partition start */
|
|
|
|
cur_rank= 1;
|
|
|
|
row_number= 0;
|
2016-02-05 16:50:50 +03:00
|
|
|
}
|
2016-02-06 01:53:17 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool add() override;
|
2016-02-06 01:53:17 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
longlong val_int() override
|
2016-02-06 01:53:17 +03:00
|
|
|
{
|
|
|
|
return cur_rank;
|
2016-02-05 16:50:50 +03:00
|
|
|
}
|
2016-02-06 01:53:17 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void reset_field() override { DBUG_ASSERT(0); }
|
|
|
|
void update_field() override {}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func () const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
|
|
|
return RANK_FUNC;
|
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("rank") };
|
|
|
|
return name;
|
2016-02-12 20:33:56 -08:00
|
|
|
}
|
2016-03-03 18:45:37 +02:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void setup_window_func(THD *thd, Window_spec *window_spec) override;
|
2016-09-01 18:10:15 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void cleanup() override
|
2016-03-24 02:09:17 +03:00
|
|
|
{
|
2016-09-01 18:10:15 +03:00
|
|
|
if (peer_tracker)
|
2016-09-12 18:50:47 +02:00
|
|
|
{
|
|
|
|
delete peer_tracker;
|
|
|
|
peer_tracker= NULL;
|
|
|
|
}
|
2016-03-24 02:09:17 +03:00
|
|
|
Item_sum_int::cleanup();
|
|
|
|
}
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_rank>(thd, this); }
|
2016-02-12 20:33:56 -08:00
|
|
|
};
|
|
|
|
|
2016-02-05 16:50:50 +03:00
|
|
|
|
|
|
|
/*
|
2016-02-16 00:22:12 +02:00
|
|
|
DENSE_RANK() OVER (...) Windowing function
|
2016-02-05 16:50:50 +03:00
|
|
|
|
2016-02-06 01:53:17 +03:00
|
|
|
@detail
|
2016-02-05 16:50:50 +03:00
|
|
|
- This is a Window function (not just an aggregate)
|
|
|
|
- It can be computed by doing one pass over select output, provided
|
|
|
|
the output is sorted according to the window definition.
|
2016-02-06 01:53:17 +03:00
|
|
|
|
|
|
|
The function is defined as:
|
|
|
|
|
|
|
|
"If DENSE_RANK is specified, then the rank of row R is defined as the
|
|
|
|
number of rows preceding and including R that are distinct with respect
|
|
|
|
to the window ordering"
|
|
|
|
|
|
|
|
"This implies that there are no gaps in the sequential rank numbering of
|
|
|
|
rows in each window partition."
|
2016-02-05 16:50:50 +03:00
|
|
|
*/
|
|
|
|
|
2016-02-06 01:53:17 +03:00
|
|
|
|
2016-02-12 20:33:56 -08:00
|
|
|
class Item_sum_dense_rank: public Item_sum_int
|
|
|
|
{
|
|
|
|
longlong dense_rank;
|
2016-04-13 10:39:06 +02:00
|
|
|
bool first_add;
|
2016-09-01 18:10:15 +03:00
|
|
|
Group_bound_tracker *peer_tracker;
|
2016-04-13 10:39:06 +02:00
|
|
|
public:
|
2016-02-16 00:33:53 +02:00
|
|
|
/*
|
|
|
|
XXX(cvicentiu) This class could potentially be implemented in the rank
|
|
|
|
class, with a switch for the DENSE case.
|
|
|
|
*/
|
2020-08-19 02:53:22 +03:00
|
|
|
void clear() override
|
2016-02-16 00:33:53 +02:00
|
|
|
{
|
2016-04-10 07:51:42 +03:00
|
|
|
dense_rank= 0;
|
2016-04-13 10:39:06 +02:00
|
|
|
first_add= true;
|
2016-02-16 00:22:12 +02:00
|
|
|
}
|
2020-08-19 02:53:22 +03:00
|
|
|
bool add() override;
|
|
|
|
void reset_field() override { DBUG_ASSERT(0); }
|
|
|
|
void update_field() override {}
|
|
|
|
longlong val_int() override
|
2016-02-16 00:33:53 +02:00
|
|
|
{
|
2016-02-16 00:22:12 +02:00
|
|
|
return dense_rank;
|
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
|
|
|
Item_sum_dense_rank(THD *thd)
|
2016-09-01 18:10:15 +03:00
|
|
|
: Item_sum_int(thd), dense_rank(0), first_add(true), peer_tracker(NULL) {}
|
2020-08-19 02:53:22 +03:00
|
|
|
const Type_handler *type_handler() const override
|
|
|
|
{ return &type_handler_slonglong; }
|
|
|
|
enum Sumfunctype sum_func () const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
|
|
|
return DENSE_RANK_FUNC;
|
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("dense_rank") };
|
|
|
|
return name;
|
2016-02-12 20:33:56 -08:00
|
|
|
}
|
2016-02-16 00:22:12 +02:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void setup_window_func(THD *thd, Window_spec *window_spec) override;
|
2016-02-16 00:22:12 +02:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void cleanup() override
|
2016-03-24 02:09:17 +03:00
|
|
|
{
|
2016-09-01 18:10:15 +03:00
|
|
|
if (peer_tracker)
|
|
|
|
{
|
|
|
|
delete peer_tracker;
|
2016-09-12 18:50:47 +02:00
|
|
|
peer_tracker= NULL;
|
2016-09-01 18:10:15 +03:00
|
|
|
}
|
2016-03-24 02:09:17 +03:00
|
|
|
Item_sum_int::cleanup();
|
|
|
|
}
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_dense_rank>(thd, this); }
|
2016-02-12 20:33:56 -08:00
|
|
|
};
|
|
|
|
|
2019-08-07 14:13:44 +04:00
|
|
|
class Item_sum_hybrid_simple : public Item_sum_hybrid
|
2016-09-22 18:26:55 +02:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_sum_hybrid_simple(THD *thd, Item *arg):
|
2019-08-07 14:13:44 +04:00
|
|
|
Item_sum_hybrid(thd, arg),
|
2016-09-22 18:26:55 +02:00
|
|
|
value(NULL)
|
2019-08-07 14:13:44 +04:00
|
|
|
{ }
|
2016-09-22 18:26:55 +02:00
|
|
|
|
|
|
|
Item_sum_hybrid_simple(THD *thd, Item *arg1, Item *arg2):
|
2019-08-07 14:13:44 +04:00
|
|
|
Item_sum_hybrid(thd, arg1, arg2),
|
2016-09-22 18:26:55 +02:00
|
|
|
value(NULL)
|
2019-08-07 14:13:44 +04:00
|
|
|
{ }
|
2016-09-22 18:26:55 +02:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool add() override;
|
|
|
|
bool fix_fields(THD *, Item **) override;
|
2022-01-26 03:02:45 +05:30
|
|
|
bool fix_length_and_dec(THD *thd) override;
|
2016-09-22 18:26:55 +02:00
|
|
|
void setup_hybrid(THD *thd, Item *item);
|
2020-08-19 02:53:22 +03:00
|
|
|
double val_real() override;
|
|
|
|
longlong val_int() override;
|
|
|
|
my_decimal *val_decimal(my_decimal *) override;
|
|
|
|
void reset_field() override;
|
|
|
|
String *val_str(String *) override;
|
|
|
|
bool val_native(THD *thd, Native *to) override;
|
|
|
|
bool get_date(THD *thd, MYSQL_TIME *ltime, date_mode_t fuzzydate) override;
|
|
|
|
const Type_handler *type_handler() const override
|
2017-05-06 19:12:59 +04:00
|
|
|
{ return Type_handler_hybrid_field_type::type_handler(); }
|
2020-08-19 02:53:22 +03:00
|
|
|
void update_field() override;
|
|
|
|
Field *create_tmp_field(MEM_ROOT *root, bool group, TABLE *table) override;
|
|
|
|
void clear() override
|
2016-09-22 18:26:55 +02:00
|
|
|
{
|
|
|
|
value->clear();
|
|
|
|
null_value= 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
Item_cache *value;
|
|
|
|
};
|
|
|
|
|
2016-09-20 20:44:49 +02:00
|
|
|
/*
|
|
|
|
This item will remember the first value added to it. It will not update
|
|
|
|
the value unless it is cleared.
|
|
|
|
*/
|
2016-09-22 18:26:55 +02:00
|
|
|
class Item_sum_first_value : public Item_sum_hybrid_simple
|
2016-09-20 20:44:49 +02:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_sum_first_value(THD* thd, Item* arg_expr) :
|
2017-02-07 16:49:41 +02:00
|
|
|
Item_sum_hybrid_simple(thd, arg_expr) {}
|
2016-09-20 20:44:49 +02:00
|
|
|
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func () const override
|
2016-09-20 20:44:49 +02:00
|
|
|
{
|
|
|
|
return FIRST_VALUE_FUNC;
|
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-09-20 20:44:49 +02:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("first_value") };
|
|
|
|
return name;
|
2016-09-20 20:44:49 +02:00
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_first_value>(thd, this); }
|
2016-09-20 20:44:49 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
This item will remember the last value added to it.
|
|
|
|
|
|
|
|
This item does not support removal, and can be cleared only by calling
|
|
|
|
clear().
|
|
|
|
*/
|
2016-09-22 18:26:55 +02:00
|
|
|
class Item_sum_last_value : public Item_sum_hybrid_simple
|
2016-09-20 20:44:49 +02:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_sum_last_value(THD* thd, Item* arg_expr) :
|
2016-09-22 18:26:55 +02:00
|
|
|
Item_sum_hybrid_simple(thd, arg_expr) {}
|
2016-09-20 20:44:49 +02:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func() const override
|
2016-09-20 20:44:49 +02:00
|
|
|
{
|
|
|
|
return LAST_VALUE_FUNC;
|
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-09-20 20:44:49 +02:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("last_value") };
|
|
|
|
return name;
|
2016-09-20 20:44:49 +02:00
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_last_value>(thd, this); }
|
2016-09-20 20:44:49 +02:00
|
|
|
};
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
|
2016-09-22 22:18:45 +02:00
|
|
|
class Item_sum_nth_value : public Item_sum_hybrid_simple
|
2016-09-22 18:26:55 +02:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_sum_nth_value(THD *thd, Item *arg_expr, Item* offset_expr) :
|
2016-09-22 22:18:45 +02:00
|
|
|
Item_sum_hybrid_simple(thd, arg_expr, offset_expr) {}
|
2016-09-22 18:26:55 +02:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func() const override
|
2016-09-22 18:26:55 +02:00
|
|
|
{
|
|
|
|
return NTH_VALUE_FUNC;
|
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-09-22 18:26:55 +02:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("nth_value") };
|
|
|
|
return name;
|
2016-09-22 18:26:55 +02:00
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_nth_value>(thd, this); }
|
2016-09-22 18:26:55 +02:00
|
|
|
};
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
|
2016-09-22 18:26:55 +02:00
|
|
|
class Item_sum_lead : public Item_sum_hybrid_simple
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_sum_lead(THD *thd, Item *arg_expr, Item* offset_expr) :
|
|
|
|
Item_sum_hybrid_simple(thd, arg_expr, offset_expr) {}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func() const override
|
2016-09-22 18:26:55 +02:00
|
|
|
{
|
|
|
|
return LEAD_FUNC;
|
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-09-22 18:26:55 +02:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("lead") };
|
|
|
|
return name;
|
2016-09-22 18:26:55 +02:00
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_lead>(thd, this); }
|
2016-09-22 18:26:55 +02:00
|
|
|
};
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
|
2016-09-22 18:26:55 +02:00
|
|
|
class Item_sum_lag : public Item_sum_hybrid_simple
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_sum_lag(THD *thd, Item *arg_expr, Item* offset_expr) :
|
|
|
|
Item_sum_hybrid_simple(thd, arg_expr, offset_expr) {}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func() const override
|
2016-09-22 18:26:55 +02:00
|
|
|
{
|
|
|
|
return LAG_FUNC;
|
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-09-22 18:26:55 +02:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("lag") };
|
|
|
|
return name;
|
2016-09-22 18:26:55 +02:00
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_lag>(thd, this); }
|
2016-09-22 18:26:55 +02:00
|
|
|
};
|
|
|
|
|
2016-03-28 22:11:00 +03:00
|
|
|
|
2019-12-25 12:23:24 +04:00
|
|
|
class Partition_row_count
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Partition_row_count() :partition_row_count_(0) { }
|
|
|
|
void set_partition_row_count(ulonglong count)
|
|
|
|
{
|
|
|
|
partition_row_count_ = count;
|
|
|
|
}
|
|
|
|
double calc_val_real(bool *null_value,
|
|
|
|
ulonglong current_row_count)
|
|
|
|
{
|
|
|
|
if ((*null_value= (partition_row_count_ == 0)))
|
|
|
|
return 0;
|
|
|
|
return static_cast<double>(current_row_count) / partition_row_count_;
|
|
|
|
}
|
|
|
|
protected:
|
2016-03-28 22:11:00 +03:00
|
|
|
longlong get_row_count() { return partition_row_count_; }
|
|
|
|
ulonglong partition_row_count_;
|
2016-03-03 18:45:37 +02:00
|
|
|
};
|
2016-02-06 01:53:17 +03:00
|
|
|
|
2019-12-25 12:23:24 +04:00
|
|
|
|
|
|
|
class Current_row_count
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Current_row_count() :current_row_count_(0) { }
|
|
|
|
protected:
|
|
|
|
ulonglong get_row_number() { return current_row_count_ ; }
|
|
|
|
ulonglong current_row_count_;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2016-02-06 01:53:17 +03:00
|
|
|
/*
|
|
|
|
@detail
|
|
|
|
"The relative rank of a row R is defined as (RK-1)/(NR-1), where RK is
|
|
|
|
defined to be the RANK of R and NR is defined to be the number of rows in
|
|
|
|
the window partition of R."
|
|
|
|
|
|
|
|
Computation of this function requires two passes:
|
|
|
|
- First pass to find #rows in the partition
|
2016-03-03 18:45:37 +02:00
|
|
|
This is held within the row_count context.
|
2016-02-06 01:53:17 +03:00
|
|
|
- Second pass to compute rank of current row and the value of the function
|
|
|
|
*/
|
2019-12-25 12:23:24 +04:00
|
|
|
class Item_sum_percent_rank: public Item_sum_double,
|
|
|
|
public Partition_row_count
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
Item_sum_percent_rank(THD *thd)
|
2019-12-25 12:23:24 +04:00
|
|
|
: Item_sum_double(thd), cur_rank(1), peer_tracker(NULL) {}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
longlong val_int() override
|
2016-03-03 18:45:37 +02:00
|
|
|
{
|
|
|
|
/*
|
|
|
|
Percent rank is a real value so calling the integer value should never
|
|
|
|
happen. It makes no sense as it gets truncated to either 0 or 1.
|
|
|
|
*/
|
|
|
|
DBUG_ASSERT(0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
double val_real() override
|
2016-03-03 18:45:37 +02:00
|
|
|
{
|
|
|
|
/*
|
|
|
|
We can not get the real value without knowing the number of rows
|
|
|
|
in the partition. Don't divide by 0.
|
|
|
|
*/
|
2016-03-28 22:11:00 +03:00
|
|
|
ulonglong partition_rows = get_row_count();
|
|
|
|
null_value= partition_rows > 0 ? false : true;
|
|
|
|
|
2016-03-03 18:45:37 +02:00
|
|
|
return partition_rows > 1 ?
|
|
|
|
static_cast<double>(cur_rank - 1) / (partition_rows - 1) : 0;
|
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func () const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
|
|
|
return PERCENT_RANK_FUNC;
|
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("percent_rank") };
|
|
|
|
return name;
|
2016-02-12 20:33:56 -08:00
|
|
|
}
|
2016-03-03 18:45:37 +02:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void update_field() override {}
|
2016-03-03 18:45:37 +02:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void clear() override
|
2016-03-03 18:45:37 +02:00
|
|
|
{
|
|
|
|
cur_rank= 1;
|
|
|
|
row_number= 0;
|
|
|
|
}
|
2020-08-19 02:53:22 +03:00
|
|
|
bool add() override;
|
|
|
|
const Type_handler *type_handler() const override
|
|
|
|
{ return &type_handler_double; }
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2022-01-26 03:02:45 +05:30
|
|
|
bool fix_length_and_dec(THD *thd) override
|
2016-03-03 18:45:37 +02:00
|
|
|
{
|
|
|
|
decimals = 10; // TODO-cvicentiu find out how many decimals the standard
|
|
|
|
// requires.
|
2018-05-08 15:26:26 +02:00
|
|
|
return FALSE;
|
2016-03-03 18:45:37 +02:00
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void setup_window_func(THD *thd, Window_spec *window_spec) override;
|
2019-12-25 12:23:24 +04:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void reset_field() override { DBUG_ASSERT(0); }
|
2019-12-25 13:33:28 +04:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void set_partition_row_count(ulonglong count) override
|
2019-12-25 12:23:24 +04:00
|
|
|
{
|
|
|
|
Partition_row_count::set_partition_row_count(count);
|
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_percent_rank>(thd, this); }
|
2016-03-03 18:45:37 +02:00
|
|
|
|
|
|
|
private:
|
|
|
|
longlong cur_rank; // Current rank of the current row.
|
|
|
|
longlong row_number; // Value if this were ROW_NUMBER() function.
|
|
|
|
|
2016-09-01 18:10:15 +03:00
|
|
|
Group_bound_tracker *peer_tracker;
|
2016-03-24 02:09:17 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void cleanup() override
|
2016-03-24 02:09:17 +03:00
|
|
|
{
|
2016-09-01 18:10:15 +03:00
|
|
|
if (peer_tracker)
|
|
|
|
{
|
|
|
|
delete peer_tracker;
|
2016-09-12 18:50:47 +02:00
|
|
|
peer_tracker= NULL;
|
2016-09-01 18:10:15 +03:00
|
|
|
}
|
2016-04-01 15:29:45 -07:00
|
|
|
Item_sum_num::cleanup();
|
2016-03-03 18:45:37 +02:00
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
};
|
|
|
|
|
2016-02-06 01:53:17 +03:00
|
|
|
|
2016-03-03 18:45:37 +02:00
|
|
|
|
|
|
|
|
2016-02-06 01:53:17 +03:00
|
|
|
/*
|
|
|
|
@detail
|
|
|
|
"The relative rank of a row R is defined as NP/NR, where
|
|
|
|
- NP is defined to be the number of rows preceding or peer with R in the
|
|
|
|
window ordering of the window partition of R
|
|
|
|
- NR is defined to be the number of rows in the window partition of R.
|
|
|
|
|
2016-03-28 22:48:32 +03:00
|
|
|
Just like with Item_sum_percent_rank, computation of this function requires
|
2016-02-06 01:53:17 +03:00
|
|
|
two passes.
|
|
|
|
*/
|
|
|
|
|
2019-12-25 12:23:24 +04:00
|
|
|
class Item_sum_cume_dist: public Item_sum_double,
|
|
|
|
public Partition_row_count,
|
|
|
|
public Current_row_count
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
|
|
|
public:
|
2019-12-25 12:23:24 +04:00
|
|
|
Item_sum_cume_dist(THD *thd) :Item_sum_double(thd) { }
|
|
|
|
Item_sum_cume_dist(THD *thd, Item *arg) :Item_sum_double(thd, arg) { }
|
2017-06-22 21:43:45 +05:30
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
double val_real() override
|
2016-03-28 22:48:32 +03:00
|
|
|
{
|
2019-12-25 12:23:24 +04:00
|
|
|
return calc_val_real(&null_value, current_row_count_);
|
2016-03-28 22:48:32 +03:00
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool add() override
|
2016-03-28 22:48:32 +03:00
|
|
|
{
|
|
|
|
current_row_count_++;
|
|
|
|
return false;
|
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func() const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
|
|
|
return CUME_DIST_FUNC;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void clear() override
|
2016-03-28 22:48:32 +03:00
|
|
|
{
|
|
|
|
current_row_count_= 0;
|
2019-12-25 12:23:24 +04:00
|
|
|
partition_row_count_= 0;
|
2016-03-28 22:48:32 +03:00
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("cume_dist") };
|
|
|
|
return name;
|
2016-02-12 20:33:56 -08:00
|
|
|
}
|
2016-03-28 22:48:32 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void update_field() override {}
|
|
|
|
const Type_handler *type_handler() const override
|
|
|
|
{ return &type_handler_double; }
|
2016-03-28 22:48:32 +03:00
|
|
|
|
2022-01-26 03:02:45 +05:30
|
|
|
bool fix_length_and_dec(THD *thd) override
|
2016-03-28 22:48:32 +03:00
|
|
|
{
|
|
|
|
decimals = 10; // TODO-cvicentiu find out how many decimals the standard
|
|
|
|
// requires.
|
2018-05-08 15:26:26 +02:00
|
|
|
return FALSE;
|
2016-03-28 22:48:32 +03:00
|
|
|
}
|
2016-05-01 22:29:47 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void reset_field() override { DBUG_ASSERT(0); }
|
2016-03-28 22:48:32 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void set_partition_row_count(ulonglong count) override
|
2017-06-22 21:43:45 +05:30
|
|
|
{
|
2019-12-25 12:23:24 +04:00
|
|
|
Partition_row_count::set_partition_row_count(count);
|
2017-06-22 21:43:45 +05:30
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2019-12-25 12:23:24 +04:00
|
|
|
{ return get_item_copy<Item_sum_cume_dist>(thd, this); }
|
|
|
|
|
2016-02-12 20:33:56 -08:00
|
|
|
};
|
|
|
|
|
2019-12-25 12:23:24 +04:00
|
|
|
class Item_sum_ntile : public Item_sum_int,
|
|
|
|
public Partition_row_count,
|
|
|
|
public Current_row_count
|
2016-04-04 17:06:12 +03:00
|
|
|
{
|
|
|
|
public:
|
2016-04-04 22:03:50 +03:00
|
|
|
Item_sum_ntile(THD* thd, Item* num_quantiles_expr) :
|
2020-07-31 13:51:28 +03:00
|
|
|
Item_sum_int(thd, num_quantiles_expr), n_old_val_(0)
|
2019-12-25 12:23:24 +04:00
|
|
|
{ }
|
2016-04-04 17:06:12 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
longlong val_int() override
|
2016-04-04 17:06:12 +03:00
|
|
|
{
|
|
|
|
if (get_row_count() == 0)
|
|
|
|
{
|
|
|
|
null_value= true;
|
|
|
|
return 0;
|
|
|
|
}
|
2016-04-05 16:58:50 +03:00
|
|
|
|
2016-04-13 11:06:05 +02:00
|
|
|
longlong num_quantiles= get_num_quantiles();
|
2016-04-05 16:58:50 +03:00
|
|
|
|
2020-06-18 11:02:19 +03:00
|
|
|
if (num_quantiles <= 0 ||
|
|
|
|
(static_cast<ulonglong>(num_quantiles) != n_old_val_ && n_old_val_ > 0))
|
|
|
|
{
|
2016-04-05 16:58:50 +03:00
|
|
|
my_error(ER_INVALID_NTILE_ARGUMENT, MYF(0));
|
|
|
|
return true;
|
|
|
|
}
|
2020-06-18 11:02:19 +03:00
|
|
|
n_old_val_= static_cast<ulonglong>(num_quantiles);
|
2016-04-04 17:06:12 +03:00
|
|
|
null_value= false;
|
2016-04-05 16:58:50 +03:00
|
|
|
ulonglong quantile_size = get_row_count() / num_quantiles;
|
|
|
|
ulonglong extra_rows = get_row_count() - quantile_size * num_quantiles;
|
2016-04-04 17:06:12 +03:00
|
|
|
|
|
|
|
if (current_row_count_ <= extra_rows * (quantile_size + 1))
|
|
|
|
return (current_row_count_ - 1) / (quantile_size + 1) + 1;
|
|
|
|
|
|
|
|
return (current_row_count_ - 1 - extra_rows) / quantile_size + 1;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool add() override
|
2016-04-04 17:06:12 +03:00
|
|
|
{
|
|
|
|
current_row_count_++;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func() const override
|
2016-04-04 17:06:12 +03:00
|
|
|
{
|
|
|
|
return NTILE_FUNC;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void clear() override
|
2016-04-04 17:06:12 +03:00
|
|
|
{
|
|
|
|
current_row_count_= 0;
|
2019-12-25 12:23:24 +04:00
|
|
|
partition_row_count_= 0;
|
2020-06-18 11:02:19 +03:00
|
|
|
n_old_val_= 0;
|
2016-04-04 17:06:12 +03:00
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2016-04-04 17:06:12 +03:00
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("ntile") };
|
|
|
|
return name;
|
2016-04-04 17:06:12 +03:00
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void update_field() override {}
|
2016-04-04 17:06:12 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
const Type_handler *type_handler() const override
|
|
|
|
{ return &type_handler_slonglong; }
|
2019-12-27 21:17:16 +02:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void reset_field() override { DBUG_ASSERT(0); }
|
2019-12-25 13:33:28 +04:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void set_partition_row_count(ulonglong count) override
|
2019-12-25 12:23:24 +04:00
|
|
|
{
|
|
|
|
Partition_row_count::set_partition_row_count(count);
|
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_ntile>(thd, this); }
|
2016-04-04 17:06:12 +03:00
|
|
|
|
|
|
|
private:
|
2016-04-13 11:06:05 +02:00
|
|
|
longlong get_num_quantiles() { return args[0]->val_int(); }
|
2020-06-18 11:02:19 +03:00
|
|
|
ulonglong n_old_val_;
|
2016-04-04 17:06:12 +03:00
|
|
|
};
|
|
|
|
|
2019-12-25 12:23:24 +04:00
|
|
|
class Item_sum_percentile_disc : public Item_sum_num,
|
|
|
|
public Type_handler_hybrid_field_type,
|
|
|
|
public Partition_row_count,
|
|
|
|
public Current_row_count
|
2017-06-22 21:43:45 +05:30
|
|
|
{
|
|
|
|
public:
|
2019-12-25 12:23:24 +04:00
|
|
|
Item_sum_percentile_disc(THD *thd, Item* arg) : Item_sum_num(thd, arg),
|
2019-08-15 13:16:00 +04:00
|
|
|
Type_handler_hybrid_field_type(&type_handler_slonglong),
|
2017-07-17 15:10:19 +05:30
|
|
|
value(NULL), val_calculated(FALSE), first_call(TRUE),
|
|
|
|
prev_value(0), order_item(NULL){}
|
2017-06-22 21:43:45 +05:30
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
double val_real() override
|
2017-06-22 21:43:45 +05:30
|
|
|
{
|
|
|
|
if (get_row_count() == 0 || get_arg(0)->is_null())
|
|
|
|
{
|
|
|
|
null_value= true;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
null_value= false;
|
2017-07-06 01:29:49 +05:30
|
|
|
return value->val_real();
|
2017-06-26 03:39:25 +05:30
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
longlong val_int() override
|
2017-06-26 03:39:25 +05:30
|
|
|
{
|
|
|
|
if (get_row_count() == 0 || get_arg(0)->is_null())
|
|
|
|
{
|
|
|
|
null_value= true;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
null_value= false;
|
2017-07-06 01:29:49 +05:30
|
|
|
return value->val_int();
|
2017-06-27 02:50:18 +05:30
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
my_decimal* val_decimal(my_decimal* dec) override
|
2017-06-27 02:50:18 +05:30
|
|
|
{
|
|
|
|
if (get_row_count() == 0 || get_arg(0)->is_null())
|
|
|
|
{
|
|
|
|
null_value= true;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
null_value= false;
|
2017-07-06 01:29:49 +05:30
|
|
|
return value->val_decimal(dec);
|
2017-06-22 21:43:45 +05:30
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
String* val_str(String *str) override
|
2017-07-17 13:19:20 +05:30
|
|
|
{
|
|
|
|
if (get_row_count() == 0 || get_arg(0)->is_null())
|
|
|
|
{
|
|
|
|
null_value= true;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
null_value= false;
|
|
|
|
return value->val_str(str);
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool get_date(THD *thd, MYSQL_TIME *ltime, date_mode_t fuzzydate) override
|
2019-12-25 12:23:24 +04:00
|
|
|
{
|
|
|
|
if (get_row_count() == 0 || get_arg(0)->is_null())
|
|
|
|
{
|
|
|
|
null_value= true;
|
2020-06-01 14:30:21 +04:00
|
|
|
return true;
|
2019-12-25 12:23:24 +04:00
|
|
|
}
|
|
|
|
null_value= false;
|
2019-12-25 13:33:28 +04:00
|
|
|
return value->get_date(thd, ltime, fuzzydate);
|
2019-12-25 12:23:24 +04:00
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool val_native(THD *thd, Native *to) override
|
2020-06-01 14:30:21 +04:00
|
|
|
{
|
|
|
|
if (get_row_count() == 0 || get_arg(0)->is_null())
|
|
|
|
{
|
|
|
|
null_value= true;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
null_value= false;
|
|
|
|
return value->val_native(thd, to);
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool add() override
|
2017-06-22 21:43:45 +05:30
|
|
|
{
|
2017-09-07 17:37:55 +05:30
|
|
|
Item *arg= get_arg(0);
|
2017-06-22 21:43:45 +05:30
|
|
|
if (arg->is_null())
|
2017-07-17 15:10:19 +05:30
|
|
|
return false;
|
2017-06-27 02:50:18 +05:30
|
|
|
|
2017-07-06 01:29:49 +05:30
|
|
|
if (first_call)
|
|
|
|
{
|
|
|
|
prev_value= arg->val_real();
|
2017-09-07 17:37:55 +05:30
|
|
|
if (prev_value > 1 || prev_value < 0)
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
2017-10-27 00:16:13 +05:30
|
|
|
my_error(ER_ARGUMENT_OUT_OF_RANGE, MYF(0), func_name());
|
2017-07-07 17:37:06 +05:30
|
|
|
return true;
|
|
|
|
}
|
2017-07-06 01:29:49 +05:30
|
|
|
first_call= false;
|
|
|
|
}
|
2017-06-27 02:50:18 +05:30
|
|
|
|
2017-07-17 15:10:19 +05:30
|
|
|
double arg_val= arg->val_real();
|
|
|
|
|
2017-09-07 17:37:55 +05:30
|
|
|
if (prev_value != arg_val)
|
2017-07-06 01:29:49 +05:30
|
|
|
{
|
2017-10-27 00:16:13 +05:30
|
|
|
my_error(ER_ARGUMENT_NOT_CONSTANT, MYF(0), func_name());
|
2017-07-06 01:29:49 +05:30
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (val_calculated)
|
2017-06-27 02:50:18 +05:30
|
|
|
return false;
|
|
|
|
|
2017-07-06 01:29:49 +05:30
|
|
|
value->store(order_item);
|
|
|
|
value->cache_value();
|
|
|
|
if (value->null_value)
|
2017-10-27 20:04:05 +05:30
|
|
|
return false;
|
2017-06-26 03:39:25 +05:30
|
|
|
|
2019-12-25 12:23:24 +04:00
|
|
|
current_row_count_++;
|
|
|
|
double val= calc_val_real(&null_value, current_row_count_);
|
2017-06-26 03:39:25 +05:30
|
|
|
|
2017-07-18 01:55:31 +05:30
|
|
|
if (val >= prev_value && !val_calculated)
|
2017-06-26 03:39:25 +05:30
|
|
|
val_calculated= true;
|
2017-06-22 21:43:45 +05:30
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func() const override
|
2017-06-22 21:43:45 +05:30
|
|
|
{
|
|
|
|
return PERCENTILE_DISC_FUNC;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void clear() override
|
2017-06-22 21:43:45 +05:30
|
|
|
{
|
2017-06-26 03:39:25 +05:30
|
|
|
val_calculated= false;
|
2017-07-06 01:29:49 +05:30
|
|
|
first_call= true;
|
2017-06-26 03:39:25 +05:30
|
|
|
value->clear();
|
2019-12-25 12:23:24 +04:00
|
|
|
partition_row_count_= 0;
|
|
|
|
current_row_count_= 0;
|
2017-06-22 21:43:45 +05:30
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2017-06-22 21:43:45 +05:30
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("percentile_disc") };
|
|
|
|
return name;
|
2017-06-22 21:43:45 +05:30
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void update_field() override {}
|
|
|
|
const Type_handler *type_handler() const override
|
2017-06-26 03:53:27 +05:30
|
|
|
{return Type_handler_hybrid_field_type::type_handler();}
|
2017-06-22 21:43:45 +05:30
|
|
|
|
2022-01-26 03:02:45 +05:30
|
|
|
bool fix_length_and_dec(THD *thd) override
|
2017-06-22 21:43:45 +05:30
|
|
|
{
|
2017-10-27 20:04:05 +05:30
|
|
|
decimals = 10; // TODO-cvicentiu find out how many decimals the standard
|
2017-06-22 21:43:45 +05:30
|
|
|
// requires.
|
2018-06-19 14:51:50 +02:00
|
|
|
return FALSE;
|
2017-06-22 21:43:45 +05:30
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void reset_field() override { DBUG_ASSERT(0); }
|
2019-12-25 13:33:28 +04:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void set_partition_row_count(ulonglong count) override
|
2019-12-25 12:23:24 +04:00
|
|
|
{
|
|
|
|
Partition_row_count::set_partition_row_count(count);
|
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_percentile_disc>(thd, this); }
|
2020-08-19 02:53:22 +03:00
|
|
|
void setup_window_func(THD *thd, Window_spec *window_spec) override;
|
2017-07-06 01:29:49 +05:30
|
|
|
void setup_hybrid(THD *thd, Item *item);
|
2020-08-19 02:53:22 +03:00
|
|
|
bool fix_fields(THD *thd, Item **ref) override;
|
2017-06-22 21:43:45 +05:30
|
|
|
|
2017-06-26 02:15:19 +05:30
|
|
|
private:
|
2017-07-06 01:29:49 +05:30
|
|
|
Item_cache *value;
|
2017-06-26 03:39:25 +05:30
|
|
|
bool val_calculated;
|
2017-07-06 01:29:49 +05:30
|
|
|
bool first_call;
|
|
|
|
double prev_value;
|
|
|
|
Item *order_item;
|
2017-06-22 21:43:45 +05:30
|
|
|
};
|
|
|
|
|
2019-12-25 12:23:24 +04:00
|
|
|
class Item_sum_percentile_cont : public Item_sum_double,
|
|
|
|
public Partition_row_count,
|
|
|
|
public Current_row_count
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
|
|
|
public:
|
2019-12-25 12:23:24 +04:00
|
|
|
Item_sum_percentile_cont(THD *thd, Item* arg) : Item_sum_double(thd, arg),
|
2017-07-07 17:37:06 +05:30
|
|
|
floor_value(NULL), ceil_value(NULL), first_call(TRUE),prev_value(0),
|
|
|
|
ceil_val_calculated(FALSE), floor_val_calculated(FALSE), order_item(NULL){}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
double val_real() override
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
|
|
|
if (get_row_count() == 0 || get_arg(0)->is_null())
|
|
|
|
{
|
|
|
|
null_value= true;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
null_value= false;
|
|
|
|
double val= 1 + prev_value * (get_row_count()-1);
|
|
|
|
|
|
|
|
/*
|
|
|
|
Applying the formula to get the value
|
|
|
|
If (CRN = FRN = RN) then the result is (value of expression from row at RN)
|
|
|
|
Otherwise the result is
|
|
|
|
(CRN - RN) * (value of expression for row at FRN) +
|
|
|
|
(RN - FRN) * (value of expression for row at CRN)
|
|
|
|
*/
|
|
|
|
|
|
|
|
if(ceil(val) == floor(val))
|
|
|
|
return floor_value->val_real();
|
|
|
|
|
|
|
|
double ret_val= ((val - floor(val)) * ceil_value->val_real()) +
|
|
|
|
((ceil(val) - val) * floor_value->val_real());
|
|
|
|
|
|
|
|
return ret_val;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool add() override
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
2017-09-07 17:37:55 +05:30
|
|
|
Item *arg= get_arg(0);
|
2017-07-07 17:37:06 +05:30
|
|
|
if (arg->is_null())
|
2017-07-17 15:10:19 +05:30
|
|
|
return false;
|
2017-07-07 17:37:06 +05:30
|
|
|
|
|
|
|
if (first_call)
|
|
|
|
{
|
|
|
|
first_call= false;
|
|
|
|
prev_value= arg->val_real();
|
2017-09-07 17:37:55 +05:30
|
|
|
if (prev_value > 1 || prev_value < 0)
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
2017-10-27 00:16:13 +05:30
|
|
|
my_error(ER_ARGUMENT_OUT_OF_RANGE, MYF(0), func_name());
|
2017-07-07 17:37:06 +05:30
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-17 15:10:19 +05:30
|
|
|
double arg_val= arg->val_real();
|
2017-09-07 17:37:55 +05:30
|
|
|
if (prev_value != arg_val)
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
2017-10-27 00:16:13 +05:30
|
|
|
my_error(ER_ARGUMENT_NOT_CONSTANT, MYF(0), func_name());
|
2017-07-07 17:37:06 +05:30
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!floor_val_calculated)
|
|
|
|
{
|
|
|
|
floor_value->store(order_item);
|
|
|
|
floor_value->cache_value();
|
|
|
|
if (floor_value->null_value)
|
2017-10-27 20:04:05 +05:30
|
|
|
return false;
|
2017-07-07 17:37:06 +05:30
|
|
|
}
|
|
|
|
if (floor_val_calculated && !ceil_val_calculated)
|
|
|
|
{
|
|
|
|
ceil_value->store(order_item);
|
|
|
|
ceil_value->cache_value();
|
|
|
|
if (ceil_value->null_value)
|
2017-10-27 20:04:05 +05:30
|
|
|
return false;
|
2017-07-07 17:37:06 +05:30
|
|
|
}
|
|
|
|
|
2019-12-25 12:23:24 +04:00
|
|
|
current_row_count_++;
|
2017-07-07 17:37:06 +05:30
|
|
|
double val= 1 + prev_value * (get_row_count()-1);
|
|
|
|
|
|
|
|
if (!floor_val_calculated && get_row_number() == floor(val))
|
2017-10-27 20:04:05 +05:30
|
|
|
floor_val_calculated= true;
|
2017-07-07 17:37:06 +05:30
|
|
|
|
|
|
|
if (!ceil_val_calculated && get_row_number() == ceil(val))
|
2017-10-27 20:04:05 +05:30
|
|
|
ceil_val_calculated= true;
|
2017-07-07 17:37:06 +05:30
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Sumfunctype sum_func() const override
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
2017-07-17 15:10:19 +05:30
|
|
|
return PERCENTILE_CONT_FUNC;
|
2017-07-07 17:37:06 +05:30
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void clear() override
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
|
|
|
first_call= true;
|
|
|
|
floor_value->clear();
|
|
|
|
ceil_value->clear();
|
|
|
|
floor_val_calculated= false;
|
|
|
|
ceil_val_calculated= false;
|
2019-12-25 12:23:24 +04:00
|
|
|
partition_row_count_= 0;
|
|
|
|
current_row_count_= 0;
|
2017-07-07 17:37:06 +05:30
|
|
|
}
|
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("percentile_cont") };
|
|
|
|
return name;
|
2017-07-07 17:37:06 +05:30
|
|
|
}
|
2020-08-19 02:53:22 +03:00
|
|
|
void update_field() override {}
|
2017-07-07 17:37:06 +05:30
|
|
|
|
2022-01-26 03:02:45 +05:30
|
|
|
bool fix_length_and_dec(THD *thd) override
|
2017-07-07 17:37:06 +05:30
|
|
|
{
|
2017-10-27 20:04:05 +05:30
|
|
|
decimals = 10; // TODO-cvicentiu find out how many decimals the standard
|
2017-07-07 17:37:06 +05:30
|
|
|
// requires.
|
2018-06-19 14:51:50 +02:00
|
|
|
return FALSE;
|
2017-07-07 17:37:06 +05:30
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void reset_field() override { DBUG_ASSERT(0); }
|
2019-12-25 13:33:28 +04:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void set_partition_row_count(ulonglong count) override
|
2019-12-25 12:23:24 +04:00
|
|
|
{
|
|
|
|
Partition_row_count::set_partition_row_count(count);
|
|
|
|
}
|
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override
|
2017-11-22 08:01:07 +02:00
|
|
|
{ return get_item_copy<Item_sum_percentile_cont>(thd, this); }
|
2020-08-19 02:53:22 +03:00
|
|
|
void setup_window_func(THD *thd, Window_spec *window_spec) override;
|
2017-07-07 17:37:06 +05:30
|
|
|
void setup_hybrid(THD *thd, Item *item);
|
2020-08-19 02:53:22 +03:00
|
|
|
bool fix_fields(THD *thd, Item **ref) override;
|
2017-07-07 17:37:06 +05:30
|
|
|
|
|
|
|
private:
|
|
|
|
Item_cache *floor_value;
|
|
|
|
Item_cache *ceil_value;
|
|
|
|
bool first_call;
|
|
|
|
double prev_value;
|
|
|
|
bool ceil_val_calculated;
|
|
|
|
bool floor_val_calculated;
|
|
|
|
Item *order_item;
|
|
|
|
};
|
|
|
|
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2017-07-06 01:29:49 +05:30
|
|
|
|
|
|
|
|
2016-03-21 20:00:05 -07:00
|
|
|
class Item_window_func : public Item_func_or_sum
|
2016-02-12 20:33:56 -08:00
|
|
|
{
|
2016-02-14 21:00:05 +03:00
|
|
|
/* Window function parameters as we've got them from the parser */
|
2016-02-18 01:25:26 +03:00
|
|
|
public:
|
2017-04-23 19:39:57 +03:00
|
|
|
LEX_CSTRING *window_name;
|
2016-02-14 21:00:05 +03:00
|
|
|
public:
|
2016-02-12 20:33:56 -08:00
|
|
|
Window_spec *window_spec;
|
2016-02-14 21:00:05 +03:00
|
|
|
|
2016-02-12 20:33:56 -08:00
|
|
|
public:
|
2017-04-23 19:39:57 +03:00
|
|
|
Item_window_func(THD *thd, Item_sum *win_func, LEX_CSTRING *win_name)
|
2016-03-21 20:00:05 -07:00
|
|
|
: Item_func_or_sum(thd, (Item *) win_func),
|
2016-02-05 14:12:17 +03:00
|
|
|
window_name(win_name), window_spec(NULL),
|
2016-02-14 21:00:05 +03:00
|
|
|
force_return_blank(true),
|
2016-03-24 03:08:43 +03:00
|
|
|
read_value_from_result_field(false) {}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
|
|
|
Item_window_func(THD *thd, Item_sum *win_func, Window_spec *win_spec)
|
2016-03-21 20:00:05 -07:00
|
|
|
: Item_func_or_sum(thd, (Item *) win_func),
|
2016-02-05 14:12:17 +03:00
|
|
|
window_name(NULL), window_spec(win_spec),
|
2016-02-14 21:00:05 +03:00
|
|
|
force_return_blank(true),
|
2016-03-24 03:08:43 +03:00
|
|
|
read_value_from_result_field(false) {}
|
2016-03-21 20:00:05 -07:00
|
|
|
|
2016-03-28 16:57:41 +03:00
|
|
|
Item_sum *window_func() const { return (Item_sum *) args[0]; }
|
2016-03-21 20:00:05 -07:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void update_used_tables() override;
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2016-04-08 03:21:25 +03:00
|
|
|
/*
|
|
|
|
This is used by filesort to mark the columns it needs to read (because they
|
|
|
|
participate in the sort criteria and/or row retrieval. Window functions can
|
|
|
|
only be used in sort criteria).
|
|
|
|
|
|
|
|
Sorting by window function value is only done after the window functions
|
|
|
|
have been computed. In that case, window function will need to read its
|
|
|
|
temp.table field. In order to allow that, mark that field in the read_set.
|
|
|
|
*/
|
2020-08-19 02:53:22 +03:00
|
|
|
bool register_field_in_read_map(void *arg) override
|
2016-04-08 03:21:25 +03:00
|
|
|
{
|
|
|
|
TABLE *table= (TABLE*) arg;
|
|
|
|
if (result_field && (result_field->table == table || !table))
|
|
|
|
{
|
|
|
|
bitmap_set_bit(result_field->table->read_set, result_field->field_index);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2016-03-28 16:57:41 +03:00
|
|
|
bool is_frame_prohibited() const
|
2016-03-18 00:33:53 -07:00
|
|
|
{
|
2016-03-21 20:00:05 -07:00
|
|
|
switch (window_func()->sum_func()) {
|
2016-03-18 00:33:53 -07:00
|
|
|
case Item_sum::ROW_NUMBER_FUNC:
|
|
|
|
case Item_sum::RANK_FUNC:
|
|
|
|
case Item_sum::DENSE_RANK_FUNC:
|
|
|
|
case Item_sum::PERCENT_RANK_FUNC:
|
|
|
|
case Item_sum::CUME_DIST_FUNC:
|
2016-04-04 17:06:12 +03:00
|
|
|
case Item_sum::NTILE_FUNC:
|
2017-06-22 21:43:45 +05:30
|
|
|
case Item_sum::PERCENTILE_CONT_FUNC:
|
|
|
|
case Item_sum::PERCENTILE_DISC_FUNC:
|
2016-09-21 16:45:36 +02:00
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool requires_special_cursors() const
|
|
|
|
{
|
|
|
|
switch (window_func()->sum_func()) {
|
2016-09-20 22:12:48 +02:00
|
|
|
case Item_sum::FIRST_VALUE_FUNC:
|
|
|
|
case Item_sum::LAST_VALUE_FUNC:
|
2016-09-22 22:18:45 +02:00
|
|
|
case Item_sum::NTH_VALUE_FUNC:
|
2016-09-22 18:26:55 +02:00
|
|
|
case Item_sum::LAG_FUNC:
|
|
|
|
case Item_sum::LEAD_FUNC:
|
2016-03-18 00:33:53 -07:00
|
|
|
return true;
|
2016-09-21 16:45:36 +02:00
|
|
|
default:
|
2016-03-18 00:33:53 -07:00
|
|
|
return false;
|
2016-03-28 22:11:00 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool requires_partition_size() const
|
|
|
|
{
|
|
|
|
switch (window_func()->sum_func()) {
|
|
|
|
case Item_sum::PERCENT_RANK_FUNC:
|
|
|
|
case Item_sum::CUME_DIST_FUNC:
|
2016-04-04 17:06:12 +03:00
|
|
|
case Item_sum::NTILE_FUNC:
|
2017-06-22 21:43:45 +05:30
|
|
|
case Item_sum::PERCENTILE_CONT_FUNC:
|
|
|
|
case Item_sum::PERCENTILE_DISC_FUNC:
|
2016-03-28 22:11:00 +03:00
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool requires_peer_size() const
|
|
|
|
{
|
|
|
|
switch (window_func()->sum_func()) {
|
|
|
|
case Item_sum::CUME_DIST_FUNC:
|
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
2016-03-18 00:33:53 -07:00
|
|
|
}
|
2016-03-18 10:52:02 -07:00
|
|
|
}
|
|
|
|
|
2016-03-28 16:57:41 +03:00
|
|
|
bool is_order_list_mandatory() const
|
2016-03-18 10:52:02 -07:00
|
|
|
{
|
2016-03-21 20:00:05 -07:00
|
|
|
switch (window_func()->sum_func()) {
|
2016-03-18 10:52:02 -07:00
|
|
|
case Item_sum::RANK_FUNC:
|
|
|
|
case Item_sum::DENSE_RANK_FUNC:
|
|
|
|
case Item_sum::PERCENT_RANK_FUNC:
|
|
|
|
case Item_sum::CUME_DIST_FUNC:
|
2018-03-17 01:22:53 +08:00
|
|
|
case Item_sum::LAG_FUNC:
|
|
|
|
case Item_sum::LEAD_FUNC:
|
2017-06-22 21:43:45 +05:30
|
|
|
case Item_sum::PERCENTILE_CONT_FUNC:
|
|
|
|
case Item_sum::PERCENTILE_DISC_FUNC:
|
2016-03-18 10:52:02 -07:00
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
2016-03-18 00:33:53 -07:00
|
|
|
}
|
|
|
|
|
2017-06-26 02:15:19 +05:30
|
|
|
bool only_single_element_order_list() const
|
|
|
|
{
|
2017-07-18 01:55:31 +05:30
|
|
|
switch (window_func()->sum_func()){
|
2017-06-26 02:15:19 +05:30
|
|
|
case Item_sum::PERCENTILE_CONT_FUNC:
|
|
|
|
case Item_sum::PERCENTILE_DISC_FUNC:
|
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-17 15:02:22 +05:30
|
|
|
bool check_result_type_of_order_item();
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-02-05 14:12:17 +03:00
|
|
|
/*
|
|
|
|
Computation functions.
|
2016-02-18 01:25:26 +03:00
|
|
|
TODO: consoder merging these with class Group_bound_tracker.
|
2016-02-05 14:12:17 +03:00
|
|
|
*/
|
|
|
|
void setup_partition_border_check(THD *thd);
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
const Type_handler *type_handler() const override
|
2017-05-06 19:12:59 +04:00
|
|
|
{
|
|
|
|
return ((Item_sum *) args[0])->type_handler();
|
|
|
|
}
|
2020-08-19 02:53:22 +03:00
|
|
|
enum Item::Type type() const override { return Item::WINDOW_FUNC_ITEM; }
|
2016-03-24 03:08:43 +03:00
|
|
|
|
|
|
|
private:
|
2016-02-05 00:52:17 +03:00
|
|
|
/*
|
2016-02-05 16:50:50 +03:00
|
|
|
Window functions are very special functions, so val_() methods have
|
2016-02-05 00:52:17 +03:00
|
|
|
special meaning for them:
|
|
|
|
|
2016-03-24 02:57:03 +03:00
|
|
|
- Phase#1, "Initial" we run the join and put its result into temporary
|
|
|
|
table. For window functions, we write the default value (NULL?) as
|
|
|
|
a placeholder.
|
2016-02-05 00:52:17 +03:00
|
|
|
|
2016-03-24 02:57:03 +03:00
|
|
|
- Phase#2: "Computation": executor does the scan in {PARTITION, ORDER BY}
|
|
|
|
order of this window function. It calls appropriate methods to inform
|
|
|
|
the window function about rows entering/leaving the window.
|
|
|
|
It calls window_func()->val_int() so that current window function value
|
2016-02-05 00:52:17 +03:00
|
|
|
can be saved and stored in the temp.table.
|
|
|
|
|
2016-03-24 02:57:03 +03:00
|
|
|
- Phase#3: "Retrieval" the temporary table is read and passed to query
|
|
|
|
output. However, Item_window_func still remains in the select list,
|
|
|
|
so item_windowfunc->val_int() will be called.
|
2016-02-05 16:50:50 +03:00
|
|
|
During Phase#3, read_value_from_result_field= true.
|
2016-02-05 00:52:17 +03:00
|
|
|
*/
|
2016-02-14 21:00:05 +03:00
|
|
|
bool force_return_blank;
|
2016-02-05 14:12:17 +03:00
|
|
|
bool read_value_from_result_field;
|
2018-10-15 09:35:19 -07:00
|
|
|
void print_for_percentile_functions(String *str, enum_query_type query_type);
|
2016-02-05 14:12:17 +03:00
|
|
|
|
|
|
|
public:
|
2016-03-24 02:57:03 +03:00
|
|
|
void set_phase_to_initial()
|
|
|
|
{
|
|
|
|
force_return_blank= true;
|
|
|
|
read_value_from_result_field= false;
|
|
|
|
}
|
|
|
|
void set_phase_to_computation()
|
|
|
|
{
|
|
|
|
force_return_blank= false;
|
|
|
|
read_value_from_result_field= false;
|
|
|
|
}
|
|
|
|
void set_phase_to_retrieval()
|
|
|
|
{
|
|
|
|
force_return_blank= false;
|
|
|
|
read_value_from_result_field= true;
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool is_null() override
|
2017-07-04 14:14:30 +04:00
|
|
|
{
|
|
|
|
if (force_return_blank)
|
|
|
|
return true;
|
|
|
|
|
|
|
|
if (read_value_from_result_field)
|
|
|
|
return result_field->is_null();
|
|
|
|
|
|
|
|
return window_func()->is_null();
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
double val_real() override
|
2016-02-05 14:12:17 +03:00
|
|
|
{
|
2016-03-16 01:26:39 +03:00
|
|
|
double res;
|
2016-02-14 21:00:05 +03:00
|
|
|
if (force_return_blank)
|
2016-03-16 01:26:39 +03:00
|
|
|
{
|
|
|
|
res= 0.0;
|
2017-07-04 14:14:30 +04:00
|
|
|
null_value= true;
|
2016-03-16 01:26:39 +03:00
|
|
|
}
|
|
|
|
else if (read_value_from_result_field)
|
|
|
|
{
|
|
|
|
res= result_field->val_real();
|
2016-03-16 01:42:45 +02:00
|
|
|
null_value= result_field->is_null();
|
2016-03-16 01:26:39 +03:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-03-21 20:00:05 -07:00
|
|
|
res= window_func()->val_real();
|
|
|
|
null_value= window_func()->null_value;
|
2016-03-16 01:26:39 +03:00
|
|
|
}
|
2016-03-16 01:08:09 +02:00
|
|
|
return res;
|
2016-02-05 14:12:17 +03:00
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
longlong val_int() override
|
2016-03-03 18:45:37 +02:00
|
|
|
{
|
2016-03-16 01:26:39 +03:00
|
|
|
longlong res;
|
2016-02-14 21:00:05 +03:00
|
|
|
if (force_return_blank)
|
2016-03-16 01:26:39 +03:00
|
|
|
{
|
|
|
|
res= 0;
|
2017-07-04 14:14:30 +04:00
|
|
|
null_value= true;
|
2016-03-16 01:26:39 +03:00
|
|
|
}
|
|
|
|
else if (read_value_from_result_field)
|
|
|
|
{
|
|
|
|
res= result_field->val_int();
|
|
|
|
null_value= result_field->is_null();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-03-21 20:00:05 -07:00
|
|
|
res= window_func()->val_int();
|
|
|
|
null_value= window_func()->null_value;
|
2016-03-16 01:26:39 +03:00
|
|
|
}
|
|
|
|
return res;
|
2016-02-05 14:12:17 +03:00
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
String* val_str(String* str) override
|
2016-02-05 14:12:17 +03:00
|
|
|
{
|
2016-03-16 01:26:39 +03:00
|
|
|
String *res;
|
2016-02-14 21:00:05 +03:00
|
|
|
if (force_return_blank)
|
2016-03-16 01:26:39 +03:00
|
|
|
{
|
2017-07-04 14:14:30 +04:00
|
|
|
null_value= true;
|
|
|
|
res= NULL;
|
2016-03-16 01:26:39 +03:00
|
|
|
}
|
|
|
|
else if (read_value_from_result_field)
|
|
|
|
{
|
|
|
|
if ((null_value= result_field->is_null()))
|
|
|
|
res= NULL;
|
|
|
|
else
|
|
|
|
res= result_field->val_str(str);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-03-21 20:00:05 -07:00
|
|
|
res= window_func()->val_str(str);
|
|
|
|
null_value= window_func()->null_value;
|
2016-03-16 01:26:39 +03:00
|
|
|
}
|
|
|
|
return res;
|
2016-02-05 14:12:17 +03:00
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool val_native(THD *thd, Native *to) override
|
2019-04-02 09:13:16 +04:00
|
|
|
{
|
|
|
|
if (force_return_blank)
|
|
|
|
return null_value= true;
|
|
|
|
if (read_value_from_result_field)
|
|
|
|
return val_native_from_field(result_field, to);
|
|
|
|
return val_native_from_item(thd, window_func(), to);
|
|
|
|
}
|
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
my_decimal* val_decimal(my_decimal* dec) override
|
2016-03-16 01:26:39 +03:00
|
|
|
{
|
|
|
|
my_decimal *res;
|
2016-02-14 21:00:05 +03:00
|
|
|
if (force_return_blank)
|
2016-02-18 01:25:26 +03:00
|
|
|
{
|
2017-07-04 14:14:30 +04:00
|
|
|
null_value= true;
|
|
|
|
res= NULL;
|
2016-03-16 01:26:39 +03:00
|
|
|
}
|
|
|
|
else if (read_value_from_result_field)
|
|
|
|
{
|
|
|
|
if ((null_value= result_field->is_null()))
|
|
|
|
res= NULL;
|
|
|
|
else
|
|
|
|
res= result_field->val_decimal(dec);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-03-21 20:00:05 -07:00
|
|
|
res= window_func()->val_decimal(dec);
|
|
|
|
null_value= window_func()->null_value;
|
2016-02-18 01:25:26 +03:00
|
|
|
}
|
2016-03-16 01:26:39 +03:00
|
|
|
return res;
|
2016-02-05 14:12:17 +03:00
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool get_date(THD *thd, MYSQL_TIME *ltime, date_mode_t fuzzydate) override
|
2018-02-13 20:37:31 +04:00
|
|
|
{
|
|
|
|
bool res;
|
|
|
|
if (force_return_blank)
|
|
|
|
{
|
|
|
|
null_value= true;
|
|
|
|
res= true;
|
|
|
|
}
|
|
|
|
else if (read_value_from_result_field)
|
|
|
|
{
|
|
|
|
if ((null_value= result_field->is_null()))
|
|
|
|
res= true;
|
|
|
|
else
|
|
|
|
res= result_field->get_date(ltime, fuzzydate);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-09-28 14:01:17 +04:00
|
|
|
res= window_func()->get_date(thd, ltime, fuzzydate);
|
2018-02-13 20:37:31 +04:00
|
|
|
null_value= window_func()->null_value;
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2016-02-26 02:08:45 +03:00
|
|
|
void split_sum_func(THD *thd, Ref_ptr_array ref_pointer_array,
|
2020-08-19 02:53:22 +03:00
|
|
|
List<Item> &fields, uint flags) override;
|
2016-09-16 20:38:22 +02:00
|
|
|
|
2022-01-26 03:02:45 +05:30
|
|
|
bool fix_length_and_dec(THD *thd) override
|
2016-02-18 01:25:26 +03:00
|
|
|
{
|
2019-08-15 13:16:00 +04:00
|
|
|
Type_std_attributes::set(window_func());
|
2018-05-08 15:26:26 +02:00
|
|
|
return FALSE;
|
2016-02-18 01:25:26 +03:00
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
Reduce usage of strlen()
Changes:
- To detect automatic strlen() I removed the methods in String that
uses 'const char *' without a length:
- String::append(const char*)
- Binary_string(const char *str)
- String(const char *str, CHARSET_INFO *cs)
- append_for_single_quote(const char *)
All usage of append(const char*) is changed to either use
String::append(char), String::append(const char*, size_t length) or
String::append(LEX_CSTRING)
- Added STRING_WITH_LEN() around constant string arguments to
String::append()
- Added overflow argument to escape_string_for_mysql() and
escape_quotes_for_mysql() instead of returning (size_t) -1 on overflow.
This was needed as most usage of the above functions never tested the
result for -1 and would have given wrong results or crashes in case
of overflows.
- Added Item_func_or_sum::func_name_cstring(), which returns LEX_CSTRING.
Changed all Item_func::func_name()'s to func_name_cstring()'s.
The old Item_func_or_sum::func_name() is now an inline function that
returns func_name_cstring().str.
- Changed Item::mode_name() and Item::func_name_ext() to return
LEX_CSTRING.
- Changed for some functions the name argument from const char * to
to const LEX_CSTRING &:
- Item::Item_func_fix_attributes()
- Item::check_type_...()
- Type_std_attributes::agg_item_collations()
- Type_std_attributes::agg_item_set_converter()
- Type_std_attributes::agg_arg_charsets...()
- Type_handler_hybrid_field_type::aggregate_for_result()
- Type_handler_geometry::check_type_geom_or_binary()
- Type_handler::Item_func_or_sum_illegal_param()
- Predicant_to_list_comparator::add_value_skip_null()
- Predicant_to_list_comparator::add_value()
- cmp_item_row::prepare_comparators()
- cmp_item_row::aggregate_row_elements_for_comparison()
- Cursor_ref::print_func()
- Removes String_space() as it was only used in one cases and that
could be simplified to not use String_space(), thanks to the fixed
my_vsnprintf().
- Added some const LEX_CSTRING's for common strings:
- NULL_clex_str, DATA_clex_str, INDEX_clex_str.
- Changed primary_key_name to a LEX_CSTRING
- Renamed String::set_quick() to String::set_buffer_if_not_allocated() to
clarify what the function really does.
- Rename of protocol function:
bool store(const char *from, CHARSET_INFO *cs) to
bool store_string_or_null(const char *from, CHARSET_INFO *cs).
This was done to both clarify the difference between this 'store' function
and also to make it easier to find unoptimal usage of store() calls.
- Added Protocol::store(const LEX_CSTRING*, CHARSET_INFO*)
- Changed some 'const char*' arrays to instead be of type LEX_CSTRING.
- class Item_func_units now used LEX_CSTRING for name.
Other things:
- Fixed a bug in mysql.cc:construct_prompt() where a wrong escape character
in the prompt would cause some part of the prompt to be duplicated.
- Fixed a lot of instances where the length of the argument to
append is known or easily obtain but was not used.
- Removed some not needed 'virtual' definition for functions that was
inherited from the parent. I added override to these.
- Fixed Ordered_key::print() to preallocate needed buffer. Old code could
case memory overruns.
- Simplified some loops when adding char * to a String with delimiters.
2020-08-12 20:29:55 +03:00
|
|
|
LEX_CSTRING func_name_cstring() const override
|
|
|
|
{
|
|
|
|
static LEX_CSTRING name= {STRING_WITH_LEN("WF") };
|
|
|
|
return name;
|
|
|
|
}
|
2016-02-12 20:33:56 -08:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
bool fix_fields(THD *thd, Item **ref) override;
|
2016-02-19 23:20:09 -08:00
|
|
|
|
2016-03-03 18:45:37 +02:00
|
|
|
bool resolve_window_name(THD *thd);
|
2016-05-01 22:29:47 +03:00
|
|
|
|
2020-08-19 02:53:22 +03:00
|
|
|
void print(String *str, enum_query_type query_type) override;
|
2016-09-29 01:15:00 -07:00
|
|
|
|
MDEV-34490 get_copy() and build_clone() may return an instance of an ancestor class instead of a copy/clone
The `Item` class methods `get_copy()`, `build_clone()`, and `clone_item()`
face an issue where they may be defined in a descendant class
(e.g., `Item_func`) but not in a further descendant (e.g., `Item_func_child`).
This can lead to scenarios where `build_clone()`, when operating on an
instance of `Item_func_child` with a pointer to the base class (`Item`),
returns an instance of `Item_func` instead of `Item_func_child`.
Since this limitation cannot be resolved at compile time, this commit
introduces runtime type checks for the copy/clone operations.
A debug assertion will now trigger in case of a type mismatch.
`get_copy()`, `build_clone()`, and `clone_item()` are no more virtual,
but virtual `do_get_copy()`, `do_build_clone()`, and `do_clone_item()`
are added to the protected section of the class `Item`.
Additionally, const qualifiers have been added to certain methods
to enhance code reliability.
Reviewer: Oleksandr Byelkin <sanja@mariadb.com>
2024-07-03 15:42:21 +07:00
|
|
|
Item *do_get_copy(THD *thd) const override { return 0; }
|
2016-03-18 00:33:53 -07:00
|
|
|
|
2016-02-12 20:33:56 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* ITEM_WINDOWFUNC_INCLUDED */
|