1#ifndef ITEM_SUM_INCLUDED
2#define ITEM_SUM_INCLUDED
54#include "mysqld_error.h"
579 if (item ==
nullptr)
return nullptr;
604 bool eq(
const Item *item)
const override;
800 snprintf(buff,
sizeof(buff),
"%s as window function",
func_name());
917 void clear()
override;
919 void endup()
override;
1015 return static_cast<double>(
val_int());
1068 void clear()
override;
1069 bool add()
override;
1089 void clear()
override;
1090 bool add()
override;
1174 pointer_cast<Check_function_as_value_generator_parameters *>(args);
1263 template <
typename... Args>
1267 Args &&...parent_args);
1309 const char *
func_name()
const override {
return "json_arrayagg"; }
1311 void clear()
override;
1312 bool add()
override;
1346 const char *
func_name()
const override {
return "json_objectagg"; }
1348 void clear()
override;
1349 bool add()
override;
1373 void clear()
override;
1374 bool add()
override;
1406 pointer_cast<Check_function_as_value_generator_parameters *>(args);
1503 void clear()
override;
1504 bool add()
override;
1514 return sample ?
"var_samp" :
"variance";
1538 pointer_cast<Check_function_as_value_generator_parameters *>(args);
1558 return sample ?
"stddev_samp" :
"std";
1696 void clear()
override;
1722 bool add()
override;
1874 void clear()
override;
1897 bool add()
override;
1952 const char *
func_name()
const override {
return "bit_and"; }
1964 const char *
func_name()
const override {
return "bit_xor"; }
1999 if (
udf.
fix_fields(thd,
this, this->arg_count, this->args))
return true;
2005 void clear()
override;
2006 bool add()
override;
2080 const char *end_not_used;
2084 &end_not_used, &err_not_used)
2095 return cs->cset->strtoll10(
cs, res->
ptr(), &
end, &err_not_used);
2213 const char *
func_name()
const override {
return "group_concat"; }
2216 void clear()
override;
2217 bool add()
override;
2228 const char *end_ptr = res->
ptr() + res->
length();
2258 context = pointer_cast<Item_ident::Change_context *>(arg)->m_context;
2321 const char *
func_name()
const override {
return "row_number"; }
2334 void clear()
override;
2369 return m_dense ?
"dense_rank" :
"rank";
2392 void clear()
override;
2405 const char *
func_name()
const override {
return "cume_dist"; }
2446 const char *
func_name()
const override {
return "percent_rank"; }
2458 void clear()
override;
2549 void clear()
override;
2619 return m_is_first ?
"first_value" :
"last_value";
2627 void clear()
override;
2689 const char *
func_name()
const override {
return "nth_value"; }
2696 void clear()
override;
2748 const char *
func_name()
const override {
return "grouping"; }
2773 :
Item_sum((*sum_func_per_level)[0]),
2775 args = (*THR_MALLOC)->ArrayAlloc<
Item *>(sum_func_per_level->
size());
2777 for (
Item &item : *sum_func_per_level) {
2797 const char *
func_name()
const override {
return "rollup_sum_switcher"; }
2814 void clear()
override;
2844 Item *ret =
nullptr;
2863 return down_cast<Item_sum *>(
args[i]);
2902 if (
aggr !=
nullptr) {
2908 return aggr ? false :
true;
2926 bool add()
override;
2931 void clear()
override;
2932 const char *
func_name()
const override {
return "st_collect"; }
Kerberos Client Authentication nullptr
Definition: auth_kerberos_client_plugin.cc:247
The distinct aggregator.
Definition: item_sum.h:819
uint tree_key_length
Definition: item_sum.h:872
uint32 * field_lengths
Definition: item_sum.h:849
bool arg_is_null(bool use_null_value) override
NULLness of being-aggregated argument.
Definition: item_sum.cc:2251
bool endup_done
Definition: item_sum.h:830
Const_distinct
Definition: item_sum.h:874
@ CONST_NULL
Set to true if the result is known to be always NULL.
Definition: item_sum.h:885
@ CONST_NOT_NULL
Set to true if count distinct is on only const items.
Definition: item_sum.h:892
@ NOT_CONST
Definition: item_sum.h:875
static int composite_key_cmp(const void *arg, const void *a, const void *b)
Correctly compare composite keys.
Definition: item_sum.cc:1033
void endup() override
Calculate the aggregate function value.
Definition: item_sum.cc:1426
~Aggregator_distinct() override
Definition: item_sum.cc:2201
bool use_distinct_values
When feeding back the data in endup() from Unique/temp table back to Item_sum::add() methods we must ...
Definition: item_sum.h:903
double arg_val_real() override
Floating point value of being-aggregated argument.
Definition: item_sum.cc:2246
void clear() override
Invalidate calculated value and clear the distinct rows.
Definition: item_sum.cc:1320
bool setup(THD *) override
Called before feeding the first row.
Definition: item_sum.cc:1104
bool unique_walk_function(void *element)
Aggregate a distinct row from the distinct hash table.
Definition: item_sum.cc:2194
Unique * tree
Definition: item_sum.h:864
Temp_table_param * tmp_table_param
Definition: item_sum.h:855
bool add() override
Process incoming row.
Definition: item_sum.cc:1352
TABLE * table
Definition: item_sum.h:841
Aggregator_type Aggrtype() override
Definition: item_sum.h:914
my_decimal * arg_val_decimal(my_decimal *value) override
Decimal value of being-aggregated argument.
Definition: item_sum.cc:2241
enum Aggregator_distinct::Const_distinct const_distinct
Aggregator_distinct(Item_sum *sum)
Definition: item_sum.h:906
The pass-through aggregator.
Definition: item_sum.h:933
void clear() override
Called when we need to wipe out all the data from the aggregator: all the values accumulated and all ...
Definition: item_sum.h:939
Aggregator_simple(Item_sum *sum)
Definition: item_sum.h:935
bool setup(THD *thd) override
Called before adding the first row.
Definition: item_sum.h:938
Aggregator_type Aggrtype() override
Definition: item_sum.h:936
my_decimal * arg_val_decimal(my_decimal *value) override
Decimal value of being-aggregated argument.
Definition: item_sum.cc:2218
void endup() override
Called when there are no more data and the final value is to be retrieved.
Definition: item_sum.h:941
double arg_val_real() override
Floating point value of being-aggregated argument.
Definition: item_sum.cc:2222
bool add() override
Called when there's a new value to be aggregated.
Definition: item_sum.h:940
bool arg_is_null(bool use_null_value) override
NULLness of being-aggregated argument.
Definition: item_sum.cc:2226
The abstract base class for the Aggregator_* classes.
Definition: item_sum.h:101
Item_sum * item_sum
Definition: item_sum.h:113
virtual bool arg_is_null(bool use_null_value)=0
NULLness of being-aggregated argument.
Aggregator_type
Definition: item_sum.h:119
@ SIMPLE_AGGREGATOR
Definition: item_sum.h:119
@ DISTINCT_AGGREGATOR
Definition: item_sum.h:119
virtual bool add()=0
Called when there's a new value to be aggregated.
virtual void endup()=0
Called when there are no more data and the final value is to be retrieved.
virtual Aggregator_type Aggrtype()=0
virtual ~Aggregator()=default
virtual my_decimal * arg_val_decimal(my_decimal *value)=0
Decimal value of being-aggregated argument.
virtual void clear()=0
Called when we need to wipe out all the data from the aggregator: all the values accumulated and all ...
Aggregator(Item_sum *arg)
Definition: item_sum.h:116
virtual double arg_val_real()=0
Floating point value of being-aggregated argument.
virtual bool setup(THD *)=0
Called before adding the first row.
Definition: item_cmpfunc.h:145
void set(const DTCollation &dt)
Definition: item.h:204
Date_val is a temporal type that represents dates within the range 0000-01-01 and 9999-12-31.
Definition: my_temporal.h:421
Definition: my_temporal.h:341
Definition: item_sum.h:1203
Item_aggr_avg_field(Item_sum_avg *item)
Definition: item_sum.cc:3857
String * val_str(String *) override
Definition: item_sum.cc:3899
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:3885
uint m_prec_increment
Definition: item_sum.h:1215
uint m_dec_bin_size
Definition: item_sum.h:1214
double val_real() override
Definition: item_sum.cc:3874
enum Type type() const override
Definition: item_sum.h:1206
uint m_scale
Definition: item_sum.h:1213
uint m_precision
Definition: item_sum.h:1212
This is used in connection with an Item_sum_bit,.
Definition: item_sum.h:1219
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.cc:3982
enum Type type() const override
Definition: item_sum.h:1229
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.cc:3997
ulonglong m_reset_bits
Definition: item_sum.h:1232
longlong val_int() override
Definition: item_sum.cc:3921
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.cc:3989
double val_real() override
Definition: item_sum.cc:3936
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:3953
String * val_str(String *) override
Definition: item_sum.cc:3961
Item_aggr_bit_field(Item_sum_bit *item, ulonglong reset_bits)
Definition: item_sum.cc:3904
Common abstract class for aggregate field classes that return numeric values: Item_aggr_avg_field Ite...
Definition: item_sum.h:1185
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:1194
longlong val_int() override
Definition: item_sum.h:1187
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:1191
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:1197
bool is_null() override
The method allows to determine nullness of a complex expression without fully evaluating it,...
Definition: item_sum.h:1200
Definition: item_sum.h:1529
enum Type type() const override
Definition: item_sum.h:1532
enum Item_result result_type() const override
Definition: item_sum.h:1535
bool check_function_as_value_generator(uchar *args) override
Check if this item is allowed for a virtual column or inside a default expression.
Definition: item_sum.h:1536
double val_real() override
Definition: item_sum.cc:4007
Item_aggr_std_field(Item_sum_std *item)
Definition: item_sum.cc:4004
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:4013
Definition: item_sum.h:1395
double val_real() override
Definition: item_sum.cc:4047
Item_aggr_variance_field(Item_sum_variance *item)
Definition: item_sum.cc:4035
bool check_function_as_value_generator(uchar *args) override
Check if this item is allowed for a virtual column or inside a default expression.
Definition: item_sum.h:1404
String * val_str(String *str) override
Definition: item_sum.h:1400
my_decimal * val_decimal(my_decimal *dec_buf) override
Definition: item_sum.h:1401
uint m_sample
Definition: item_sum.h:1412
enum Type type() const override
Definition: item_sum.h:1398
This is used in connection with a parent aggregate Item:
Definition: item_sum.h:1154
bool mark_field_in_map(uchar *arg) override
Mark underlying field in read or write map of a table.
Definition: item_sum.h:1165
Item_result m_result_type
Stores the Item's result type.
Definition: item_sum.h:1159
Field * m_field
The tmp table's column containing the value of the set function.
Definition: item_sum.h:1157
bool check_function_as_value_generator(uchar *args) override
Check if this item is allowed for a virtual column or inside a default expression.
Definition: item_sum.h:1172
bool resolve_type(THD *) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:1164
enum Item_result result_type() const override
Definition: item_sum.h:1162
CUME_DIST window function, cf.
Definition: item_sum.h:2399
Item_cume_dist(const POS &pos, PT_window *w)
Definition: item_sum.h:2403
Item_non_framing_wf super
Definition: item_sum.h:2400
double val_real() override
Definition: item_sum.cc:5099
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2406
void clear() override
Definition: item_sum.h:2417
const char * func_name() const override
Definition: item_sum.h:2405
bool needs_partition_cardinality() const override
Return true if we need to make two passes over the rows in the partition - either because we need the...
Definition: item_sum.h:2416
String * val_str(String *) override
Definition: item_sum.cc:5119
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:5089
longlong val_int() override
Definition: item_sum.cc:5111
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:2408
my_decimal * val_decimal(my_decimal *buffer) override
Definition: item_sum.cc:5123
Item_result result_type() const override
Definition: item_sum.h:2422
FIRST_VALUE/LAST_VALUE window functions, cf.
Definition: item_sum.h:2600
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2622
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.cc:5438
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.cc:5327
void reset_field() override
Definition: item_sum.h:2642
const char * func_name() const override
Definition: item_sum.h:2618
bool setup_first_last()
Definition: item_sum.cc:5369
double val_real() override
Definition: item_sum.cc:5418
String * val_str(String *str) override
Definition: item_sum.cc:5481
void update_after_wf_arguments_changed(THD *thd) override
Signal to the function that its arguments may have changed, and that any internal caches etc.
Definition: item_sum.cc:5386
bool split_sum_func(THD *thd, Ref_item_array ref_item_array, mem_root_deque< Item * > *fields) override
See comments in Item_cmp_func::split_sum_func()
Definition: item_sum.cc:5357
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:5313
bool compute()
Core logic of FIRST/LAST_VALUE window functions.
Definition: item_sum.cc:5390
int64 cnt
used when evaluating on-the-fly (non-buffered processing)
Definition: item_sum.h:2605
Item_result m_hybrid_type
Definition: item_sum.h:2603
enum Item_result result_type() const override
Definition: item_sum.h:2630
Item_cache * m_value
Definition: item_sum.h:2604
bool val_json(Json_wrapper *wr) override
Get a JSON value from an Item.
Definition: item_sum.cc:5459
void update_field() override
Definition: item_sum.h:2643
enum_null_treatment m_null_treatment
Definition: item_sum.h:2602
Item_sum super
Definition: item_sum.h:2606
void clear() override
Definition: item_sum.cc:5380
bool uses_only_one_row() const override
Only for framing window functions.
Definition: item_sum.h:2651
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.cc:5428
bool add() override
Definition: item_sum.h:2644
Item_first_last_value(const POS &pos, bool first, Item *a, enum_null_treatment null_treatment, PT_window *w)
Definition: item_sum.h:2609
bool m_is_first
if true, the function is FIRST_VALUE, else LAST_VALUE
Definition: item_sum.h:2601
longlong val_int() override
Definition: item_sum.cc:5408
my_decimal * val_decimal(my_decimal *decimal_buffer) override
Definition: item_sum.cc:5469
bool fix_fields(THD *thd, Item **items) override
Definition: item_sum.cc:5338
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.cc:5449
Definition: item_sum.h:2144
void clear() override
Definition: item_sum.cc:4561
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:2237
bool m_result_finalized
True if result has been written to output buffer.
Definition: item_sum.h:2183
String result
Definition: item_sum.h:2159
Item_func_group_concat * original
Following is 0 normal object and pointer to original one for copy (to correctly free resources)
Definition: item_sum.h:2188
longlong val_int() override
Definition: item_sum.h:2224
const String * get_separator_str() const noexcept
Definition: item_sum.h:2243
uint32_t get_group_concat_max_len() const noexcept
Definition: item_sum.h:2244
my_decimal * val_decimal(my_decimal *decimal_value) override
Definition: item_sum.h:2231
friend int dump_leaf_key(void *key_arg, element_count count, void *item_arg)
Append data from current leaf to item->result.
Definition: item_sum.cc:4307
uint row_count
Definition: item_sum.h:2174
void make_unique() override
Definition: item_sum.cc:4834
bool change_context_processor(uchar *arg) override
Definition: item_sum.h:2257
bool setup(THD *thd) override
Definition: item_sum.cc:4717
Item_sum super
Definition: item_sum.h:2145
bool distinct
True if GROUP CONCAT has the DISTINCT attribute.
Definition: item_sum.h:2148
TABLE * table
Temporary table used to perform group concat.
Definition: item_sum.h:2172
friend int group_concat_key_cmp_with_distinct(const void *arg, const void *key1, const void *key2)
Compares the values for fields in expr list of GROUP_CONCAT.
Definition: item_sum.cc:4228
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:2238
double val_real() override
Definition: item_sum.cc:4842
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2212
String * val_str(String *str) override
Definition: item_sum.cc:4849
friend int group_concat_key_cmp_with_order(const void *arg, const void *key1, const void *key2)
function of sort for syntax: GROUP_CONCAT(expr,... ORDER BY col,... )
Definition: item_sum.cc:4264
bool force_copy_fields
Definition: item_sum.h:2181
bool fix_fields(THD *, Item **) override
Definition: item_sum.cc:4624
Unique * unique_filter
If DISTINCT is used with this GROUP_CONCAT, this member is used to filter out duplicates.
Definition: item_sum.h:2170
bool check_wf_semantics1(THD *, Query_block *, Window_evaluation_requirements *) override
Only relevant for aggregates qua window functions.
Definition: item_sum.h:2262
void no_rows_in_result() override
Mark an aggregate as having no rows.
Definition: item_sum.cc:4559
Mem_root_array< ORDER > order_array
Definition: item_sum.h:2173
TREE tree_base
Definition: item_sum.h:2160
void update_field() override
Definition: item_sum.h:2219
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_sum.cc:4874
Temp_table_param * tmp_table_param
Describes the temporary table used to perform group concat.
Definition: item_sum.h:2158
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_sum.cc:4486
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:4551
bool do_itemize(Parse_context *pc, Item **res) override
The core function that does the actual itemization.
Definition: item_sum.cc:4434
const char * func_name() const override
Definition: item_sum.h:2213
Item_result result_type() const override
Definition: item_sum.h:2214
Field * make_string_field(TABLE *table_arg) const override
Create a field to hold a string value from an item.
Definition: item_sum.cc:4518
uint64 hash() override
Generate hash unique to an item depending on its attributes.
Definition: item_sum.cc:4910
uint m_order_arg_count
The number of ORDER BY items.
Definition: item_sum.h:2150
TREE * tree
Definition: item_sum.h:2161
Item_func_group_concat(const POS &pos, bool is_distinct, PT_item_list *select_list, PT_order_list *opt_order_list, String *separator, PT_window *w)
Constructor of Item_func_group_concat.
Definition: item_sum.cc:4396
bool has_distinct() const noexcept
Definition: item_sum.h:2242
bool add() override
Definition: item_sum.cc:4573
Name_resolution_context * context
Resolver context, points to containing query block.
Definition: item_sum.h:2154
void reset_field() override
Definition: item_sum.h:2218
uint m_field_arg_count
The number of selected items, aka the concat field list.
Definition: item_sum.h:2152
uint group_concat_max_len
The maximum permitted result length in bytes as set in group_concat_max_len system variable.
Definition: item_sum.h:2179
bool warning_for_row
Definition: item_sum.h:2180
String * separator
String containing separator between group items.
Definition: item_sum.h:2156
~Item_func_group_concat() override
Definition: item_sum.h:2205
const Mem_root_array< ORDER > & get_order_array() const noexcept
Definition: item_sum.h:2247
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:2234
Class for implementation of the GROUPING function.
Definition: item_sum.h:2743
const Query_block * m_query_block
The query block in which this function is called.
Definition: item_sum.h:2760
bool aggregate_check_group(uchar *arg) override
This function is expected to check if GROUPING function with its arguments is "group-invariant".
Definition: item_sum.cc:6632
longlong val_int() override
Evaluation of the GROUPING function.
Definition: item_sum.cc:6581
Item_func_grouping(const POS &pos, PT_item_list *a)
Definition: item_sum.h:2745
const char * func_name() const override
Definition: item_sum.h:2748
bool fix_fields(THD *thd, Item **ref) override
Resolve GROUPING function.
Definition: item_sum.cc:6512
bool aggregate_check_distinct(uchar *arg) override
Used by Distinct_check::check_query to determine whether an error should be returned if the GROUPING ...
Definition: item_sum.cc:6602
bool check_args_found_in_group_by() const
Definition: item_sum.cc:6550
bool check_function_as_value_generator(uchar *) override
Check if this item is allowed for a virtual column or inside a default expression.
Definition: item_sum.cc:6564
void update_used_tables() override
Updates used tables, not null tables information and accumulates properties up the item tree,...
Definition: item_sum.cc:6644
enum Functype functype() const override
Definition: item_sum.h:2749
Definition: item_func.h:101
Item ** args
Array of pointers to arguments.
Definition: item_func.h:108
virtual Item * get_arg(uint i)
Get the i'th argument of the function that this object represents.
Definition: item_func.h:504
Functype
Definition: item_func.h:214
@ GROUPING_FUNC
Definition: item_func.h:268
virtual uint argument_count() const
Definition: item_func.h:132
table_map used_tables_cache
Value used in calculation of result of used_tables()
Definition: item_func.h:194
virtual const char * func_name() const =0
bool param_type_is_default(THD *thd, uint start, uint end, uint step, enum_field_types def)
For arguments of this Item_func ("args" array), in range [start, start+step, start+2*step,...
Definition: item_func.cc:530
bool propagate_type(THD *thd, const Type_properties &type) override
Default implementation for all functions: Propagate base_item's type into all arguments.
Definition: item_func.cc:506
Item ** arguments() const
Definition: item_func.h:133
virtual void fix_num_length_and_dec()
Definition: item_func.cc:901
const char * original_db_name() const
Definition: item.h:4415
void set_original_field_name(const char *name_arg)
Definition: item.h:4412
const char * original_table_name() const
Definition: item.h:4416
Definition: item_func.h:1048
LEAD/LAG window functions, cf.
Definition: item_sum.h:2506
bool fix_fields(THD *thd, Item **items) override
Definition: item_sum.cc:5762
bool has_value() const
Definition: item_sum.h:2581
bool m_is_lead
if true, the function is LEAD, else LAG
Definition: item_sum.h:2508
bool needs_partition_cardinality() const override
Return true if we need to make two passes over the rows in the partition - either because we need the...
Definition: item_sum.h:2565
const char * func_name() const override
Definition: item_sum.h:2540
bool split_sum_func(THD *thd, Ref_item_array ref_item_array, mem_root_deque< Item * > *fields) override
See comments in Item_cmp_func::split_sum_func()
Definition: item_sum.cc:5822
void set_use_default(bool value)
Definition: item_sum.h:2583
String * val_str(String *str) override
Definition: item_sum.cc:5900
bool m_use_default
execution state: use default value for current row
Definition: item_sum.h:2523
enum Item_result result_type() const override
Definition: item_sum.h:2553
Item_cache * m_default
Definition: item_sum.h:2512
bool compute()
Core logic of LEAD/LAG window functions.
Definition: item_sum.cc:5949
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.cc:5922
Item_lead_lag(const POS &pos, bool lead, PT_item_list *opt_list, enum_null_treatment null_treatment, PT_window *w)
Definition: item_sum.h:2527
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:5849
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2543
enum_null_treatment m_null_treatment
Definition: item_sum.h:2507
void clear() override
Definition: item_sum.cc:5861
bool use_default() const
Definition: item_sum.h:2584
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.cc:5913
TYPELIB * get_typelib() const override
Get the typelib information for an item of type set or enum.
Definition: item_sum.cc:5771
bool m_has_value
Execution state: if set, we already have a value for current row.
Definition: item_sum.h:2522
longlong val_int() override
Definition: item_sum.cc:5873
my_decimal * val_decimal(my_decimal *decimal_buffer) override
Definition: item_sum.cc:5889
bool check_wf_semantics2(Window_evaluation_requirements *reqs) override
Like check_wf_semantics1.
Definition: item_sum.cc:5794
Item_result m_hybrid_type
Definition: item_sum.h:2510
int64 m_n
canonicalized offset value
Definition: item_sum.h:2509
double val_real() override
Definition: item_sum.cc:5881
void set_has_value(bool value)
Definition: item_sum.h:2580
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.cc:5712
bool val_json(Json_wrapper *wr) override
Get a JSON value from an Item.
Definition: item_sum.cc:5939
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.cc:5931
bool setup_lead_lag()
Definition: item_sum.cc:5833
Item_cache * m_value
Definition: item_sum.h:2511
Item_non_framing_wf super
Definition: item_sum.h:2524
void update_after_wf_arguments_changed(THD *thd) override
Signal to the function that its arguments may have changed, and that any internal caches etc.
Definition: item_sum.cc:5868
Common parent class for window functions that always work on the entire partition,...
Definition: item_sum.h:2278
Item_non_framing_wf(const POS &pos, PT_window *w)
Definition: item_sum.h:2282
bool add() override
Definition: item_sum.h:2298
Item_non_framing_wf(const POS &pos, Item *a, PT_window *w)
Definition: item_sum.h:2283
Item_non_framing_wf(const POS &pos, PT_item_list *opt_list, PT_window *w)
Definition: item_sum.h:2285
Item_sum super
Definition: item_sum.h:2279
Item_non_framing_wf(THD *thd, Item_non_framing_wf *i)
Definition: item_sum.h:2287
void update_field() override
Definition: item_sum.h:2297
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:2289
void reset_field() override
Definition: item_sum.h:2296
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:2292
bool framing() const override
All aggregates are framing, i.e.
Definition: item_sum.h:2305
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:2293
bool fix_fields(THD *thd, Item **items) override
Definition: item_sum.cc:4929
NTH_VALUE window function, cf.
Definition: item_sum.h:2667
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.cc:5692
int64 m_cnt
used when evaluating on-the-fly (non-buffered processing)
Definition: item_sum.h:2674
void update_field() override
Definition: item_sum.h:2715
bool compute()
Core logic of NTH_VALUE window functions.
Definition: item_sum.cc:5597
String * val_str(String *str) override
Definition: item_sum.cc:5662
Item_sum super
Definition: item_sum.h:2676
bool check_wf_semantics2(Window_evaluation_requirements *reqs) override
Like check_wf_semantics1.
Definition: item_sum.cc:5203
enum Item_result result_type() const override
Definition: item_sum.h:2702
Item_result m_hybrid_type
Definition: item_sum.h:2671
my_decimal * val_decimal(my_decimal *decimal_buffer) override
Definition: item_sum.cc:5650
bool setup_nth()
Definition: item_sum.cc:5556
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.cc:5682
bool fix_fields(THD *thd, Item **items) override
Definition: item_sum.cc:5505
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.cc:5672
enum_field_types m_hybrid_field_type
Definition: item_sum.h:2672
int64 m_n
The N of the function.
Definition: item_sum.h:2669
double val_real() override
Definition: item_sum.cc:5640
bool m_from_last
true iff FROM_LAST was specified
Definition: item_sum.h:2670
Item_cache * m_value
Definition: item_sum.h:2673
bool val_json(Json_wrapper *wr) override
Get a JSON value from an Item.
Definition: item_sum.cc:5702
enum_null_treatment m_null_treatment
Definition: item_sum.h:2668
void reset_field() override
Definition: item_sum.h:2714
longlong val_int() override
Definition: item_sum.cc:5630
Item_nth_value(const POS &pos, PT_item_list *a, bool from_last, enum_null_treatment null_treatment, PT_window *w)
Definition: item_sum.h:2679
void clear() override
Definition: item_sum.cc:5567
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.cc:5491
bool split_sum_func(THD *thd, Ref_item_array ref_item_array, mem_root_deque< Item * > *fields) override
See comments in Item_cmp_func::split_sum_func()
Definition: item_sum.cc:5545
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2690
void update_after_wf_arguments_changed(THD *thd) override
Signal to the function that its arguments may have changed, and that any internal caches etc.
Definition: item_sum.cc:5573
bool add() override
Definition: item_sum.h:2716
const char * func_name() const override
Definition: item_sum.h:2689
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:5577
bool uses_only_one_row() const override
Only for framing window functions.
Definition: item_sum.h:2723
NTILE window function, cf.
Definition: item_sum.h:2469
void clear() override
Definition: item_sum.h:2499
Item_non_framing_wf super
Definition: item_sum.h:2470
String * val_str(String *) override
Definition: item_sum.cc:5282
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:2482
const char * func_name() const override
Definition: item_sum.h:2479
bool needs_partition_cardinality() const override
Return true if we need to make two passes over the rows in the partition - either because we need the...
Definition: item_sum.h:2500
bool check_wf_semantics2(Window_evaluation_requirements *reqs) override
Like check_wf_semantics1.
Definition: item_sum.cc:5297
bool fix_fields(THD *thd, Item **items) override
Definition: item_sum.cc:5221
double val_real() override
Definition: item_sum.cc:5277
longlong val_int() override
Definition: item_sum.cc:5227
longlong m_value
Definition: item_sum.h:2471
my_decimal * val_decimal(my_decimal *buff) override
Definition: item_sum.cc:5284
Item_ntile(const POS &pos, Item *a, PT_window *w)
Definition: item_sum.h:2474
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2480
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:5289
Item_result result_type() const override
Definition: item_sum.h:2498
PERCENT_RANK window function, cf.
Definition: item_sum.h:2428
String * val_str(String *) override
Definition: item_sum.cc:5186
Item_percent_rank(const POS &pos, PT_window *w)
Definition: item_sum.h:2439
ulonglong m_rank_ctr
Increment when window order columns change.
Definition: item_sum.h:2431
const char * func_name() const override
Definition: item_sum.h:2446
Item_result result_type() const override
Definition: item_sum.h:2463
~Item_percent_rank() override
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:5128
ulonglong m_peers
Needed to make PERCENT_RANK same for peers.
Definition: item_sum.h:2432
double val_real() override
Definition: item_sum.cc:5152
Item_non_framing_wf super
Definition: item_sum.h:2429
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:2449
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2447
bool needs_partition_cardinality() const override
Return true if we need to make two passes over the rows in the partition - either because we need the...
Definition: item_sum.h:2456
bool m_last_peer_visited
Set when the last peer has been visited.
Definition: item_sum.h:2436
void clear() override
Definition: item_sum.cc:5195
my_decimal * val_decimal(my_decimal *buffer) override
Definition: item_sum.cc:5190
longlong val_int() override
Definition: item_sum.cc:5178
RANK or DENSE_RANK window function, cf.
Definition: item_sum.h:2348
Item_result result_type() const override
Definition: item_sum.h:2393
void update_after_wf_arguments_changed(THD *thd) override
Signal to the function that its arguments may have changed, and that any internal caches etc.
Definition: item_sum.cc:4984
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:5008
ulonglong m_duplicates
Needed to make RANK different from DENSE_RANK.
Definition: item_sum.h:2353
bool m_dense
If true, the object represents DENSE_RANK.
Definition: item_sum.h:2350
longlong val_int() override
Definition: item_sum.cc:5026
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2372
~Item_rank() override
Definition: item_sum.cc:5082
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:2376
Item_rank(const POS &pos, bool dense, PT_window *w)
Definition: item_sum.h:2357
my_decimal * val_decimal(my_decimal *buff) override
Definition: item_sum.cc:5061
const char * func_name() const override
Definition: item_sum.h:2368
double val_real() override
Definition: item_sum.cc:5054
String * val_str(String *) override
Definition: item_sum.cc:5059
ulonglong m_rank_ctr
Increment when window order columns change.
Definition: item_sum.h:2352
void clear() override
Clear state for a new partition.
Definition: item_sum.cc:5066
Mem_root_array< Cached_item * > m_previous
Values of previous row's ORDER BY items.
Definition: item_sum.h:2355
Item_non_framing_wf super
Definition: item_sum.h:2349
Item with result field.
Definition: item.h:6020
longlong llrint_with_overflow_check(double realval)
Definition: item.h:6059
A wrapper Item that contains a number of aggregate items, one for each level of rollup (see Item_roll...
Definition: item_sum.h:2770
table_map used_tables() const override
Definition: item_sum.h:2798
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.cc:6660
Field * create_tmp_field(bool group, TABLE *table) override
Definition: item_sum.cc:6725
void update_field() override
Definition: item_sum.h:2813
bool resolve_type(THD *) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:2800
Item * get_arg(uint i) override
Get the i'th argument of the function that this object represents.
Definition: item_sum.h:2841
Item * set_arg(THD *thd, uint i, Item *new_val) override
Definition: item_sum.h:2843
bool is_null() override
The method allows to determine nullness of a complex expression without fully evaluating it,...
Definition: item_sum.cc:6711
void set_current_rollup_level(int level)
Definition: item_sum.h:2853
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_sum.cc:6716
bool aggregator_setup(THD *thd) override
Called to initialize the aggregator.
Definition: item_sum.cc:6758
Item_result result_type() const override
Definition: item_sum.h:2799
String * val_str(String *str) override
Definition: item_sum.cc:6690
int set_aggregator(Aggregator::Aggregator_type aggregator) override
Definition: item_sum.cc:6747
Item_sum * unwrap_sum() override
Non-const version.
Definition: item_sum.h:2858
longlong val_int() override
Definition: item_sum.cc:6683
void reset_field() override
Definition: item_sum.h:2812
const Item_sum * unwrap_sum() const override
In case we are an Item_rollup_sum_switcher, return the underlying Item_sum, otherwise,...
Definition: item_sum.h:2857
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.cc:6671
Item_rollup_sum_switcher(List< Item > *sum_func_per_level)
Definition: item_sum.h:2772
bool aggregator_add_all()
Definition: item_sum.h:2830
Item * current_arg() const
Definition: item_sum.cc:6655
void no_rows_in_result() override
Mark an aggregate as having no rows.
Definition: item_sum.h:2819
Item_sum * master() const
Definition: item_sum.h:2854
Item_sum * child(size_t i) const
Definition: item_sum.h:2862
enum Sumfunctype real_sum_func() const override
Definition: item_sum.h:2809
bool is_rollup_sum_wrapper() const override
Overridden by Item_rollup_sum_switcher.
Definition: item_sum.h:2856
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2808
const char * func_name() const override
Definition: item_sum.h:2797
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.cc:6665
int m_current_rollup_level
Definition: item_sum.h:2867
double val_real() override
Definition: item_sum.cc:6676
bool val_json(Json_wrapper *result) override
Get a JSON value from an Item.
Definition: item_sum.cc:6704
uint argument_count() const override
Definition: item_sum.h:2850
my_decimal * val_decimal(my_decimal *dec) override
Definition: item_sum.cc:6697
bool add() override
Definition: item_sum.h:2815
void clear() override
Definition: item_sum.cc:6729
bool reset_and_add_for_rollup(int last_unchanged_group_item_idx)
Definition: item_sum.cc:6735
const int m_num_levels
Definition: item_sum.h:2866
const Item * get_arg(uint i) const override
Get the i'th argument of the function that this object represents.
Definition: item_sum.h:2842
ROW_NUMBER window function, cf.
Definition: item_sum.h:2311
ulonglong m_ctr
Increment for each row in partition.
Definition: item_sum.h:2313
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:2324
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2322
bool check_wf_semantics1(THD *, Query_block *, Window_evaluation_requirements *) override
Only relevant for aggregates qua window functions.
Definition: item_sum.h:2338
Item_row_number(const POS &pos, PT_window *w)
Definition: item_sum.h:2316
my_decimal * val_decimal(my_decimal *buff) override
Definition: item_sum.cc:4977
Item_result result_type() const override
Definition: item_sum.h:2336
String * val_str(String *) override
Definition: item_sum.cc:4973
longlong val_int() override
Definition: item_sum.cc:4954
void clear() override
Definition: item_sum.cc:4982
const char * func_name() const override
Definition: item_sum.h:2321
double val_real() override
Definition: item_sum.cc:4968
Definition: item_sum.h:1946
Item_sum_and(const POS &pos, Item *item_par, PT_window *w)
Definition: item_sum.h:1948
const char * func_name() const override
Definition: item_sum.h:1952
Item_sum_and(THD *thd, Item_sum_and *item)
Definition: item_sum.h:1951
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:3373
Definition: item_sum.h:1355
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.cc:2319
void clear() override
Definition: item_sum.cc:2375
String * val_str(String *str) override
Definition: item_sum.cc:2486
const char * func_name() const override
Definition: item_sum.h:1383
void update_field() override
calc next value and merge it with field_value.
Definition: item_sum.cc:3648
Item_sum_sum super
Definition: item_sum.h:1359
Item * result_item(Field *) override
Definition: item_sum.h:1382
double val_real() override
Definition: item_sum.cc:2384
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_sum.h:1386
Item_sum_avg(const POS &pos, Item *item_par, bool distinct, PT_window *w)
Definition: item_sum.h:1363
Field * create_tmp_field(bool group, TABLE *table) override
Definition: item_sum.cc:2353
my_decimal m_avg_dec
Definition: item_sum.h:1360
uint f_scale
Definition: item_sum.h:1358
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1370
double m_avg
Definition: item_sum.h:1361
longlong val_int() override
Definition: item_sum.h:1377
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:2346
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:2407
void reset_field() override
Definition: item_sum.cc:3544
uint prec_increment
Definition: item_sum.h:1357
uint dec_bin_size
Definition: item_sum.h:1358
bool add() override
Definition: item_sum.cc:2377
Item_sum_avg(THD *thd, Item_sum_avg *item)
Definition: item_sum.h:1366
uint f_precision
Definition: item_sum.h:1358
Base class used to implement BIT_AND, BIT_OR and BIT_XOR.
Definition: item_sum.h:1776
bool add_bits(const String *s1, ulonglong b1)
Accumulate the value of 's1' (if in string mode) or of 'b1' (if in integer mode).
Definition: item_sum.cc:1690
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_sum.h:1886
void remove_bits(const String *s1, ulonglong b1)
For windowing: perform inverse aggregation.
Definition: item_sum.cc:1612
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.cc:3255
const char initial_value_buff_storage[1]
Buffer used to avoid String allocation in the constructor.
Definition: item_sum.h:1787
static constexpr uint DIGIT_CNT_CARD
Definition: item_sum.h:1830
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1872
bool resolve_type(THD *) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.cc:1554
bool m_is_xor
true iff BIT_XOR
Definition: item_sum.h:1833
void clear() override
Definition: item_sum.cc:3345
Item * result_item(Field *) override
Definition: item_sum.h:1868
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.cc:3269
bool fix_fields(THD *thd, Item **ref) override
Definition: item_sum.cc:1529
longlong val_int() override
Definition: item_sum.cc:3321
Item_sum super
Definition: item_sum.h:1777
ulonglong * m_digit_cnt
Execution state (windowing): Used for AND, OR to be able to invert window functions in optimized mode...
Definition: item_sum.h:1822
Item_result hybrid_type
Stores the Item's result type. Can only be INT_RESULT or STRING_RESULT.
Definition: item_sum.h:1785
ulonglong reset_bits
Stores the neutral element for function.
Definition: item_sum.h:1779
Item_sum_bit(const POS &pos, Item *item_par, ulonglong reset_arg, PT_window *w)
Definition: item_sum.h:1836
bool is_and() const
Definition: item_sum.h:1899
void reset_field() override
Definition: item_sum.cc:3574
ulonglong m_count
Execution state (windowing): this is for counting rows entering and leaving the window frame,...
Definition: item_sum.h:1793
double val_real() override
Definition: item_sum.cc:3295
bool add() override
Common implementation of Item_sum_or::add, Item_sum_and:add and Item_sum_xor::add.
Definition: item_sum.cc:1774
my_decimal * val_decimal(my_decimal *decimal_value) override
Definition: item_sum.cc:3276
enum Item_result result_type() const override
Definition: item_sum.h:1873
uint m_digit_cnt_card
Definition: item_sum.h:1828
Item_sum_bit(THD *thd, Item_sum_bit *item)
Copy constructor, used for executing subqueries with temporary tables.
Definition: item_sum.h:1849
String * val_str(String *str) override
Definition: item_sum.cc:3224
void update_field() override
Definition: item_sum.cc:3584
ulonglong bits
Stores the result value for the INT_RESULT.
Definition: item_sum.h:1781
ulonglong m_frame_null_count
Execution state (windowing): this is for counting NULLs of rows entering and leaving the window frame...
Definition: item_sum.h:1801
String value_buff
Stores the result value for the STRING_RESULT.
Definition: item_sum.h:1783
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.cc:3262
Implements ST_Collect which aggregates geometries into Multipoints, Multilinestrings,...
Definition: item_sum.h:2872
bool add() override
Definition: item_sum.cc:6833
void clear() override
Definition: item_sum.cc:6827
void read_result_field()
Definition: item_sum.cc:6888
bool fix_fields(THD *thd, Item **ref) override
Definition: item_sum.cc:6796
std::optional< gis::srid_t > srid
Definition: item_sum.h:2874
Item_sum_collect(const POS &pos, Item *a, PT_window *w, bool distinct)
Definition: item_sum.h:2883
void update_field() override
Definition: item_sum.cc:6981
longlong val_int() override
Definition: item_sum.h:2890
bool val_time(Time_val *) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:2893
std::unique_ptr< gis::Geometrycollection > m_geometrycollection
Definition: item_sum.h:2875
String * val_str(String *str) override
Definition: item_sum.cc:6934
bool val_datetime(Datetime_val *, my_time_flags_t) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:2894
void reset_field() override
Definition: item_sum.cc:7044
Item_sum_collect(THD *thd, Item_sum *item)
Definition: item_sum.h:2880
void store_result_field()
Definition: item_sum.cc:6987
my_decimal * val_decimal(my_decimal *decimal_buffer) override
Definition: item_sum.cc:7039
bool check_wf_semantics1(THD *thd, Query_block *, Window_evaluation_requirements *r) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:6818
const char * func_name() const override
Definition: item_sum.h:2932
bool val_date(Date_val *, my_time_flags_t) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:2892
void pop_front()
Definition: item_sum.cc:6927
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2895
Item_result result_type() const override
Definition: item_sum.h:2896
int set_aggregator(Aggregator::Aggregator_type) override
Definition: item_sum.h:2897
double val_real() override
Definition: item_sum.h:2891
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:6883
Definition: item_sum.h:1084
longlong count
Definition: item_sum.h:1085
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:1118
longlong val_int() override
Definition: item_sum.cc:2281
Item_sum_count(Item *item, bool distinct)
Definition: item_sum.h:1097
void update_field() override
Definition: item_sum.cc:3639
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:2262
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1115
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_sum.cc:2313
void make_const(longlong count_arg)
Definition: item_sum.h:1125
void reset_field() override
Definition: item_sum.cc:3536
Item_sum_count(Item_int *number)
Definition: item_sum.h:1096
Item_sum_count(THD *thd, Item_sum_count *item)
Definition: item_sum.h:1113
Item_sum_count(const POS &pos, PT_item_list *list, PT_window *w)
Constructs an instance for COUNT(DISTINCT)
Definition: item_sum.h:1109
void clear() override
Definition: item_sum.cc:2270
const char * func_name() const override
Definition: item_sum.h:1132
Item_sum_count(const POS &pos, Item *item_par, PT_window *w)
Definition: item_sum.h:1094
void no_rows_in_result() override
Mark an aggregate as having no rows.
Definition: item_sum.h:1124
bool add() override
Definition: item_sum.cc:2272
Abstract base class for the MIN and MAX aggregate functions.
Definition: item_sum.h:1570
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:3177
void no_rows_in_result() override
Mark an aggregate as having no rows.
Definition: item_sum.cc:3172
bool setup_hybrid(Item *item, Item *value_arg)
MIN/MAX function setup.
Definition: item_sum.cc:1866
bool uses_only_one_row() const override
Only for framing window functions.
Definition: item_sum.h:1721
virtual Item_sum_hybrid * clone_hybrid(THD *thd) const =0
Create a clone of this object.
bool add() override
Definition: item_sum.cc:3207
const bool m_is_min
Tells if this is the MIN function (true) or the MAX function (false).
Definition: item_sum.h:1577
bool compute()
This function implements the optimized version of retrieving min/max value.
Definition: item_sum.cc:2911
bool has_values()
Definition: item_sum.h:1718
void min_max_update_int_field()
Definition: item_sum.cc:3822
longlong val_int() override
Definition: item_sum.cc:3044
bool m_has_values
Definition: item_sum.h:1589
void reset_field() override
Reset field before aggregation.
Definition: item_sum.cc:3403
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.cc:3086
bool split_sum_func(THD *thd, Ref_item_array ref_item_array, mem_root_deque< Item * > *fields) override
See comments in Item_cmp_func::split_sum_func()
Definition: item_sum.cc:3143
void clear() override
Definition: item_sum.cc:2862
int64 m_saved_last_value_at
Execution state: keeps track of at which row we saved a non-null last value.
Definition: item_sum.h:1617
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.cc:3106
Item_cache * arg_cache
Definition: item_sum.h:1586
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_sum.cc:3158
void min_max_update_datetime_field()
Definition: item_sum.cc:3755
void min_max_update_json_field()
Definition: item_sum.cc:3775
void update_field() override
Definition: item_sum.cc:3685
longlong val_date_temporal() override
Return date value of item in packed longlong format.
Definition: item_sum.cc:3058
void update_after_wf_arguments_changed(THD *thd) override
Signal to the function that its arguments may have changed, and that any internal caches etc.
Definition: item_sum.cc:2872
bool keep_field_type() const override
Definition: item_sum.h:1710
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:3070
int64 m_cnt
Execution state: keeps track if this is the first row in the frame when buffering is not needed.
Definition: item_sum.h:1611
void min_max_update_real_field()
Definition: item_sum.cc:3809
Item_sum_hybrid(THD *thd, const Item_sum_hybrid *item)
Definition: item_sum.h:1681
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.cc:3096
Item_result hybrid_type
Definition: item_sum.h:1588
bool m_optimize
Set to true when min/max can be optimized using window's ordering.
Definition: item_sum.h:1597
void min_max_update_time_field()
Definition: item_sum.cc:3718
Item_sum_hybrid(const POS &pos, Item *item_par, bool is_min, PT_window *w)
Definition: item_sum.h:1665
Item_sum_hybrid(Item *item_par, bool is_min)
Definition: item_sum.h:1649
Item_sum super
Definition: item_sum.h:1571
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *r) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:2877
bool fix_fields(THD *, Item **) override
Definition: item_sum.cc:1835
void min_max_update_date_field()
Definition: item_sum.cc:3737
String * val_str(String *) override
Definition: item_sum.cc:3116
Arg_comparator * cmp
Definition: item_sum.h:1587
void min_max_update_str_field()
Definition: item_sum.cc:3793
enum Item_result result_type() const override
Definition: item_sum.h:1711
void min_max_update_decimal_field()
Definition: item_sum.cc:3840
double val_real() override
Definition: item_sum.cc:3030
Field * create_tmp_field(bool group, TABLE *table) override
Definition: item_sum.cc:1883
bool m_want_first
For min() - Set to true when results are ordered in ascending and false when descending.
Definition: item_sum.h:1605
Item_cache * value
Definition: item_sum.h:1586
bool m_nulls_first
Set to true if the window is ordered ascending.
Definition: item_sum.h:1593
TYPELIB * get_typelib() const override
Get the typelib information for an item of type set or enum.
Definition: item_sum.h:1712
bool val_json(Json_wrapper *wr) override
Get a JSON value from an Item.
Definition: item_sum.cc:3129
Definition: item_sum.h:993
Item_sum_int(const POS &pos, Item *item_par, PT_window *w)
Definition: item_sum.h:995
Item_sum_int(THD *thd, Item_sum_int *item)
Definition: item_sum.h:1005
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:1023
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:1019
double val_real() override
Definition: item_sum.h:1013
Item_sum_int(Item *item_par)
Definition: item_sum.h:1009
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:1022
enum Item_result result_type() const override
Definition: item_sum.h:1026
String * val_str(String *str) override
Definition: item_sum.cc:1496
Item_sum_int(const POS &pos, PT_item_list *list, PT_window *w)
Definition: item_sum.h:1000
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:1498
Implements aggregation of values into an array.
Definition: item_sum.h:1295
Item_sum_json_array(THD *thd, Item_sum *item, unique_ptr_destroy_only< Json_wrapper > wrapper, unique_ptr_destroy_only< Json_array > array)
Definition: item_sum.cc:6245
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1310
~Item_sum_json_array() override
bool add() override
Definition: item_sum.cc:6323
unique_ptr_destroy_only< Json_array > m_json_array
Accumulates the final value.
Definition: item_sum.h:1297
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:6372
const char * func_name() const override
Definition: item_sum.h:1309
void clear() override
Definition: item_sum.cc:6263
Implements aggregation of values into an object.
Definition: item_sum.h:1317
Item_sum_json_object(THD *thd, Item_sum *item, unique_ptr_destroy_only< Json_wrapper > wrapper, unique_ptr_destroy_only< Json_object > object)
Definition: item_sum.cc:6272
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:6480
bool add() override
Definition: item_sum.cc:6385
unique_ptr_destroy_only< Json_object > m_json_object
Accumulates the final value.
Definition: item_sum.h:1319
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1347
~Item_sum_json_object() override
const char * func_name() const override
Definition: item_sum.h:1346
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:6299
std::map< std::string, int > m_key_map
Map of keys in Json_object and the count for each key within a window frame.
Definition: item_sum.h:1328
void clear() override
Definition: item_sum.cc:6289
bool m_optimize
If window provides ordering on the key in Json_object, a key_map is not needed to handle rows leaving...
Definition: item_sum.h:1336
String m_tmp_key_value
Buffer used to get the value of the key.
Definition: item_sum.h:1321
Common abstraction for Item_sum_json_array and Item_sum_json_object.
Definition: item_sum.h:1238
void reset_field() override
Definition: item_sum.cc:6205
void update_field() override
Definition: item_sum.cc:6225
bool val_json(Json_wrapper *wr) override
Get a JSON value from an Item.
Definition: item_sum.cc:6106
Json_constructor_null_clause m_json_constructor_null_clause
JSON constructor null clause.
Definition: item_sum.h:1249
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.cc:6190
unique_ptr_destroy_only< Json_wrapper > m_wrapper
Wrapper around the container (object/array) which accumulates the value.
Definition: item_sum.h:1247
longlong val_int() override
Definition: item_sum.cc:6149
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.cc:6182
String m_value
String used when reading JSON binary values or JSON text values.
Definition: item_sum.h:1243
String m_conversion_buffer
String used for converting JSON text values to utf8mb4 charset.
Definition: item_sum.h:1245
Item_sum super
Definition: item_sum.h:1239
bool do_itemize(Parse_context *pc, Item **res) override
The core function that does the actual itemization.
Definition: item_sum.cc:6050
~Item_sum_json() override
String * val_str(String *str) override
Definition: item_sum.cc:6087
my_decimal * val_decimal(my_decimal *decimal_buffer) override
Definition: item_sum.cc:6164
Item_result result_type() const override
Definition: item_sum.h:1272
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.cc:6198
bool fix_fields(THD *thd, Item **pItem) override
Definition: item_sum.cc:6024
bool check_wf_semantics1(THD *, Query_block *, Window_evaluation_requirements *) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:6019
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_sum.cc:6066
Item_sum_json(unique_ptr_destroy_only< Json_wrapper > wrapper, Json_constructor_null_clause json_constructor_null_clause, Args &&...parent_args)
Construct an Item_sum_json instance.
Definition: item_sum.cc:6007
double val_real() override
Definition: item_sum.cc:6134
Definition: item_sum.h:1757
Item_sum_max(Item *item_par)
Definition: item_sum.h:1759
Item_sum_max(THD *thd, const Item_sum_max *item)
Definition: item_sum.h:1762
const char * func_name() const override
Definition: item_sum.h:1765
Item_sum_max * clone_hybrid(THD *thd) const override
Create a clone of this object.
Definition: item_sum.cc:3188
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1764
Item_sum_max(const POS &pos, Item *item_par, PT_window *w)
Definition: item_sum.h:1760
Definition: item_sum.h:1743
Item_sum_min(THD *thd, const Item_sum_min *item)
Definition: item_sum.h:1748
Item_sum_min(Item *item_par)
Definition: item_sum.h:1745
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1750
const char * func_name() const override
Definition: item_sum.h:1751
Item_sum_min(const POS &pos, Item *item_par, PT_window *w)
Definition: item_sum.h:1746
Item_sum_min * clone_hybrid(THD *thd) const override
Create a clone of this object.
Definition: item_sum.cc:3184
Definition: item_sum.h:947
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:1492
Item_sum_num(THD *thd, Item_sum_num *item)
Definition: item_sum.h:966
bool fix_fields(THD *, Item **) override
Definition: item_sum.cc:1502
longlong val_int() override
Definition: item_sum.h:975
enum_field_types default_data_type() const override
Get the default data (output) type for the specific item.
Definition: item_sum.h:968
String * val_str(String *str) override
Definition: item_sum.cc:1490
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:984
Item_sum super
Definition: item_sum.h:948
Item_sum_num(Item *item_par)
Definition: item_sum.h:972
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:987
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:981
bool is_evaluated
Definition: item_sum.h:957
Item_sum_num(const POS &pos, Item *item_par, PT_window *window)
Definition: item_sum.h:960
void reset_field() override
Definition: item_sum.cc:3384
Item_sum_num(const POS &pos, PT_item_list *list, PT_window *w)
Definition: item_sum.h:963
Definition: item_sum.h:1936
Item_sum_or(THD *thd, Item_sum_or *item)
Definition: item_sum.h:1941
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:3359
const char * func_name() const override
Definition: item_sum.h:1942
Item_sum_or(const POS &pos, Item *item_par, PT_window *w)
Definition: item_sum.h:1938
Definition: item_sum.h:1548
double val_real() override
Definition: item_sum.cc:2496
Item_sum_std(const POS &pos, Item *item_par, uint sample_arg, PT_window *w)
Definition: item_sum.h:1550
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:2505
Item_sum_std(THD *thd, Item_sum_std *item)
Definition: item_sum.h:1553
const char * func_name() const override
Definition: item_sum.h:1557
enum Item_result result_type() const override
Definition: item_sum.h:1561
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1554
Item * result_item(Field *) override
Definition: item_sum.h:1556
Definition: item_sum.h:1029
ulonglong m_count
Execution state: this is for counting rows entering and leaving the window frame, see m_frame_null_co...
Definition: item_sum.h:1040
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:2015
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:1947
enum Item_result result_type() const override
Definition: item_sum.h:1074
double sum
Definition: item_sum.h:1032
bool add() override
Definition: item_sum.cc:2037
Item_result hybrid_type
Definition: item_sum.h:1031
void no_rows_in_result() override
Mark an aggregate as having no rows.
Definition: item_sum.cc:1966
void reset_field() override
Definition: item_sum.cc:3515
String * val_str(String *str) override
Definition: item_sum.cc:2126
longlong val_int() override
Definition: item_sum.cc:2058
my_decimal dec_buffs[2]
Definition: item_sum.h:1033
void clear() override
Definition: item_sum.cc:1954
const char * func_name() const override
Definition: item_sum.h:1080
Item_sum_sum(const POS &pos, Item *item_par, bool distinct, PT_window *window)
Definition: item_sum.h:1050
void update_field() override
calc next value and merge it with field_value.
Definition: item_sum.cc:3608
Item_sum_sum(Item *item_par)
Definition: item_sum.h:1058
uint curr_dec_buff
Definition: item_sum.h:1034
ulonglong m_frame_null_count
Execution state: this is for counting NULLs of rows entering and leaving the window frame,...
Definition: item_sum.h:1047
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:2132
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.cc:1968
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1065
double val_real() override
Definition: item_sum.cc:2082
Definition: item_sum.h:2110
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:2125
longlong val_int() override
Definition: item_sum.cc:4139
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:2121
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:4141
Item_sum_udf_decimal(const POS &pos, udf_func *udf_arg, PT_item_list *opt_list)
Definition: item_sum.h:2112
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:4150
double val_real() override
Definition: item_sum.cc:4137
enum Item_result result_type() const override
Definition: item_sum.h:2128
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:2124
String * val_str(String *) override
Definition: item_sum.cc:4133
Item_sum_udf_decimal(THD *thd, Item_sum_udf_decimal *item)
Definition: item_sum.h:2115
bool resolve_type(THD *) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:2129
Definition: item_sum.h:2015
bool resolve_type(THD *) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:2035
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:2032
longlong val_int() override
Definition: item_sum.h:2021
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:4129
String * val_str(String *str) override
Definition: item_sum.cc:4125
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:4112
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:2028
double val_real() override
Definition: item_sum.cc:4117
Item_sum_udf_float(THD *thd, Item_sum_udf_float *item)
Definition: item_sum.h:2019
Item_sum_udf_float(const POS &pos, udf_func *udf_arg, PT_item_list *opt_list)
Definition: item_sum.h:2017
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:2031
Definition: item_sum.h:2043
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:2059
Item_sum_udf_int(THD *thd, Item_sum_udf_int *item)
Definition: item_sum.h:2047
bool resolve_type(THD *) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.h:2064
enum Item_result result_type() const override
Definition: item_sum.h:2063
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:2056
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:4154
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:2060
String * val_str(String *str) override
Definition: item_sum.cc:4166
Item_sum_udf_int(const POS &pos, udf_func *udf_arg, PT_item_list *opt_list)
Definition: item_sum.h:2045
longlong val_int() override
Definition: item_sum.cc:4158
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:4170
double val_real() override
Definition: item_sum.h:2050
Definition: item_sum.h:2071
bool resolve_type(THD *) override
Default max_length is max argument length.
Definition: item_sum.cc:4176
double val_real() override
Definition: item_sum.h:2078
String * val_str(String *) override
Definition: item_sum.cc:4192
bool val_time(Time_val *time) override
Evaluate the item and return result as a time value.
Definition: item_sum.h:2101
enum Item_result result_type() const override
Definition: item_sum.h:2105
bool val_date(Date_val *date, my_time_flags_t flags) override
Evaluate the item and return result as a date value.
Definition: item_sum.h:2098
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:4184
my_decimal * val_decimal(my_decimal *dec) override
Definition: item_sum.cc:4188
Item_sum_udf_str(THD *thd, Item_sum_udf_str *item)
Definition: item_sum.h:2075
longlong val_int() override
Definition: item_sum.h:2087
bool val_datetime(Datetime_val *dt, my_time_flags_t flags) override
Evaluate the item and return result as a datetime value.
Definition: item_sum.h:2102
Item_sum_udf_str(const POS &pos, udf_func *udf_arg, PT_item_list *opt_list)
Definition: item_sum.h:2073
Definition: item_sum.h:1472
ulonglong count
Definition: item_sum.h:1483
void update_field() override
Definition: item_sum.cc:2836
bool resolve_type(THD *) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.cc:2704
double val_real() override
Definition: item_sum.cc:2781
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_sum.h:1519
void clear() override
Definition: item_sum.cc:2758
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:2724
Item * result_item(Field *) override
Definition: item_sum.h:1509
Item_sum_variance(const POS &pos, Item *item_par, uint sample_arg, PT_window *w)
Definition: item_sum.h:1493
enum Sumfunctype sum_func() const override
Definition: item_sum.h:1502
double recurrence_s
Definition: item_sum.h:1481
bool optimize
If set, uses a algorithm II mentioned in the class description to calculate the variance which helps ...
Definition: item_sum.h:1491
const char * func_name() const override
Definition: item_sum.h:1513
bool add() override
Definition: item_sum.cc:2760
void no_rows_in_result() override
Mark an aggregate as having no rows.
Definition: item_sum.h:1512
double recurrence_s2
Definition: item_sum.h:1482
Item_result hybrid_type
Definition: item_sum.h:1476
bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs) override
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:2688
double recurrence_m
Used in recurrence relation.
Definition: item_sum.h:1480
my_decimal * val_decimal(my_decimal *) override
Definition: item_sum.cc:2811
uint prec_increment
Definition: item_sum.h:1485
enum Item_result result_type() const override
Definition: item_sum.h:1518
void reset_field() override
Definition: item_sum.cc:2816
uint sample
Definition: item_sum.h:1484
Field * create_tmp_field(bool group, TABLE *table) override
Create a new field to match the type of value we're expected to yield.
Definition: item_sum.cc:2737
Definition: item_sum.h:1956
const char * func_name() const override
Definition: item_sum.h:1964
Item * copy_or_same(THD *thd) override
Definition: item_sum.cc:3366
Item_sum_xor(const POS &pos, Item *item_par, PT_window *w)
Definition: item_sum.h:1958
Item_sum_xor(THD *thd, Item_sum_xor *item)
Definition: item_sum.h:1963
Class Item_sum is the base class used for special expressions that SQL calls 'set functions'.
Definition: item_sum.h:399
virtual void update_after_wf_arguments_changed(THD *)
Signal to the function that its arguments may have changed, and that any internal caches etc.
Definition: item_sum.h:671
bool collect_grouped_aggregates(uchar *) override
Definition: item_sum.cc:750
table_map not_null_tables() const override
Return table map of tables that can't be NULL tables (tables that are used in a context where if they...
Definition: item_sum.h:590
virtual bool check_wf_semantics1(THD *thd, Query_block *select, Window_evaluation_requirements *reqs)
Only relevant for aggregates qua window functions.
Definition: item_sum.cc:427
bool m_null_executed
true if the function is determined to be NULL at start of execution
Definition: item_sum.h:514
virtual bool check_wf_semantics2(Window_evaluation_requirements *reqs)
Like check_wf_semantics1.
Definition: item_sum.h:729
void aggregator_clear()
Called to cleanup the aggregator.
Definition: item_sum.h:683
virtual const Item_sum * unwrap_sum() const
In case we are an Item_rollup_sum_switcher, return the underlying Item_sum, otherwise,...
Definition: item_sum.h:789
bool resolve_type(THD *) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_sum.cc:510
bool aggregate_check_distinct(uchar *arg) override
Definition: item_sum.cc:666
~Item_sum() override
Definition: item_sum.h:541
bool init_sum_func_check(THD *thd)
Prepare an aggregate function for checking of context.
Definition: item_sum.cc:167
virtual bool aggregator_setup(THD *thd)
Called to initialize the aggregator.
Definition: item_sum.h:677
bool wf_common_init()
Common initial actions for window functions.
Definition: item_sum.cc:983
Item_sum(const POS &pos, PT_window *w)
Definition: item_sum.h:522
bool force_copy_fields
Used in making ROLLUP.
Definition: item_sum.h:427
void no_rows_in_result() override
Mark an aggregate as having no rows.
Definition: item_sum.h:616
bool allow_group_via_temp_table
If incremental update of fields is supported.
Definition: item_sum.h:495
void add_json_info(Json_object *obj) override
Add all the node-specific json fields.
Definition: item_sum.h:804
int8 max_aggr_level
max level of unbound column references
Definition: item_sum.h:492
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_sum.cc:481
void make_const()
Definition: item_sum.h:597
Item * replace_aggregate(uchar *) override
Definition: item_sum.cc:781
Window * window()
Definition: item_sum.h:739
virtual void make_unique()
Definition: item_sum.h:621
bool eq_specific(const Item *item) const override
Provide a more specific equality check for a function.
Definition: item_sum.cc:658
bool do_itemize(Parse_context *pc, Item **res) override
The core function that does the actual itemization.
Definition: item_sum.cc:106
bool fix_fields(THD *thd, Item **ref) override
Definition: item_sum.cc:936
bool reset_and_add()
Resets the aggregate value to its default and aggregates the current value of its attribute(s).
Definition: item_sum.h:554
bool split_sum_func(THD *thd, Ref_item_array ref_item_array, mem_root_deque< Item * > *fields) override
See comments in Item_cmp_func::split_sum_func()
Definition: item_sum.cc:948
bool check_function_as_value_generator(uchar *) override
Check if this item is allowed for a virtual column or inside a default expression.
Definition: item_sum.cc:961
bool is_null() override
The method allows to determine nullness of a complex expression without fully evaluating it,...
Definition: item_sum.h:595
virtual Item * result_item(Field *field)
Definition: item_sum.h:577
bool forced_const
True means that this field has been evaluated during optimization.
Definition: item_sum.h:509
virtual void update_field()=0
bool eq(const Item *item) const override
Definition: item_sum.cc:635
bool check_sum_func(THD *thd, Item **ref)
Validate the semantic requirements of a set function.
Definition: item_sum.cc:252
bool clean_up_after_removal(uchar *arg) override
Remove the item from the list of inner aggregation functions in the Query_block it was moved to by It...
Definition: item_sum.cc:554
void unsupported_as_wf()
Definition: item_sum.h:798
Aggregator * aggr
Aggregator class instance.
Definition: item_sum.h:408
const Window * window() const
Definition: item_sum.h:740
virtual bool needs_partition_cardinality() const
Return true if we need to make two passes over the rows in the partition - either because we need the...
Definition: item_sum.h:769
virtual bool is_rollup_sum_wrapper() const
Overridden by Item_rollup_sum_switcher.
Definition: item_sum.h:783
bool aggregate_check_group(uchar *arg) override
Definition: item_sum.cc:690
bool with_distinct
Indicates how the aggregate function was specified by the parser : true if it was written as AGGREGAT...
Definition: item_sum.h:434
virtual enum Sumfunctype real_sum_func() const
Definition: item_sum.h:548
nesting_map save_deny_window_func
WFs are forbidden when resolving Item_sum; this member is used to restore WF allowance status afterwa...
Definition: item_sum.h:501
bool collect_scalar_subqueries(uchar *) override
Definition: item_sum.cc:789
virtual void reset_field()=0
virtual bool framing() const
All aggregates are framing, i.e.
Definition: item_sum.h:753
bool has_with_distinct() const
Definition: item_sum.h:438
void update_used_tables() override
Updates used tables, not null tables information and accumulates properties up the item tree,...
Definition: item_sum.cc:809
Item * set_arg(THD *thd, uint i, Item *new_val) override
Definition: item_sum.cc:889
bool m_window_resolved
True if we have already resolved this window functions window reference.
Definition: item_sum.h:418
virtual Field * create_tmp_field(bool group, TABLE *table)
Definition: item_sum.cc:723
friend class Aggregator_simple
Definition: item_sum.h:401
void add_used_tables_for_aggr_func()
Add used_tables information for aggregate function, based on its aggregated query block.
Definition: item_sum.cc:877
Item ** referenced_by[2]
For a group aggregate which is aggregated into an outer query block; none, or just the first or both ...
Definition: item_sum.h:481
bool m_null_resolved
true if the function is resolved to be always NULL
Definition: item_sum.h:512
Sumfunctype
Definition: item_sum.h:440
@ COUNT_FUNC
Definition: item_sum.h:441
@ STD_FUNC
Definition: item_sum.h:449
@ AVG_DISTINCT_FUNC
Definition: item_sum.h:446
@ DENSE_RANK_FUNC
Definition: item_sum.h:458
@ FIRST_LAST_VALUE_FUNC
Definition: item_sum.h:463
@ SUM_BIT_FUNC
Definition: item_sum.h:451
@ COUNT_DISTINCT_FUNC
Definition: item_sum.h:442
@ SUM_FUNC
Definition: item_sum.h:443
@ JSON_OBJECTAGG_FUNC
Definition: item_sum.h:454
@ CUME_DIST_FUNC
Definition: item_sum.h:459
@ SUM_DISTINCT_FUNC
Definition: item_sum.h:444
@ UDF_SUM_FUNC
Definition: item_sum.h:452
@ ROLLUP_SUM_SWITCHER_FUNC
Definition: item_sum.h:465
@ ROW_NUMBER_FUNC
Definition: item_sum.h:456
@ MAX_FUNC
Definition: item_sum.h:448
@ GEOMETRY_AGGREGATE_FUNC
Definition: item_sum.h:466
@ AVG_FUNC
Definition: item_sum.h:445
@ MIN_FUNC
Definition: item_sum.h:447
@ JSON_ARRAYAGG_FUNC
Definition: item_sum.h:455
@ NTILE_FUNC
Definition: item_sum.h:461
@ NTH_VALUE_FUNC
Definition: item_sum.h:464
@ GROUP_CONCAT_FUNC
Definition: item_sum.h:453
@ RANK_FUNC
Definition: item_sum.h:457
@ LEAD_LAG_FUNC
Definition: item_sum.h:462
@ PERCENT_RANK_FUNC
Definition: item_sum.h:460
@ VARIANCE_FUNC
Definition: item_sum.h:450
virtual int set_aggregator(Aggregator::Aggregator_type aggregator)
Definition: item_sum.cc:894
bool aggregator_add()
Called to add value to the aggregator.
Definition: item_sum.h:689
Item_sum(Item *a)
Definition: item_sum.h:525
void set_distinct(bool distinct)
Definition: item_sum.h:692
Item_sum * next_sum
next in the circular chain of registered objects
Definition: item_sum.h:483
Item_sum * in_sum_func
the containing set function if any
Definition: item_sum.h:484
virtual bool keep_field_type() const
Definition: item_sum.h:575
bool collect_item_field_or_view_ref_processor(uchar *) override
Collects fields and view references that have the qualifying table in the specified query block.
Definition: item_sum.cc:799
bool has_force_copy_fields() const
Definition: item_sum.h:437
Type type() const override
Definition: item_sum.h:544
void mark_as_sum_func()
Definition: item_sum.cc:471
Query_block * aggr_query_block
For a group aggregate, query block where function is aggregated.
Definition: item_sum.h:491
PT_window * m_window
If sum is a window function, this field contains the window.
Definition: item_sum.h:413
Item_sum(const POS &pos, Item *a, PT_window *w)
Definition: item_sum.h:530
static ulonglong ram_limitation(THD *thd)
Calculate the affordable RAM limit for structures like TREE or Unique used in Item_sum_*.
Definition: item_sum.cc:139
bool reset_wf_state(uchar *arg) override
Reset execution state for such window function types as determined by arg.
Definition: item_sum.cc:970
table_map used_tables() const override
Definition: item_sum.h:587
virtual Item_sum * unwrap_sum()
Non-const version.
Definition: item_sum.h:791
void fix_after_pullout(Query_block *parent_query_block, Query_block *removed_query_block) override
Fix after tables have been moved from one query_block level to the parent level, e....
Definition: item_sum.cc:830
virtual bool setup(THD *)
Definition: item_sum.h:707
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_sum.cc:924
int8 max_sum_func_level
max level of aggregation for contained functions
Definition: item_sum.h:494
virtual bool uses_only_one_row() const
Only for framing window functions.
Definition: item_sum.h:759
Item ** get_arg_ptr(uint i)
Definition: item_sum.h:657
virtual enum Sumfunctype sum_func() const =0
Item_sum(const POS &pos, Item *a, Item *b, PT_window *w)
Definition: item_sum.h:533
bool has_aggregate_ref_in_group_by(uchar *arg) override
Check if an aggregate is referenced from within the GROUP BY clause of the query block in which it is...
Definition: item_sum.cc:715
Query_block * base_query_block
query block where function is placed
Definition: item_sum.h:485
uint64 hash() override
Generate hash unique to an item depending on its attributes.
Definition: item_sum.cc:499
Definition: item_sum.h:1972
uint64 hash() override
Generate hash unique to an item depending on its attributes.
Definition: item_sum.cc:4104
udf_handler udf
Definition: item_sum.h:1976
bool do_itemize(Parse_context *pc, Item **res) override
The core function that does the actual itemization.
Definition: item_sum.cc:4063
void update_field() override
Definition: item_sum.h:2008
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_sum.cc:4084
void reset_field() override
Definition: item_sum.h:2007
bool add() override
Definition: item_sum.cc:4078
bool fix_fields(THD *thd, Item **ref) override
Definition: item_sum.h:1993
Item_udf_sum(const POS &pos, udf_func *udf_arg, PT_item_list *opt_list)
Definition: item_sum.h:1979
void clear() override
Definition: item_sum.cc:4072
~Item_udf_sum() override
Definition: item_sum.h:1987
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_sum.cc:4093
Item_udf_sum(THD *thd, Item_udf_sum *item)
Definition: item_sum.h:1983
Item_sum super
Definition: item_sum.h:1973
const char * func_name() const override
Definition: item_sum.h:1992
enum Sumfunctype sum_func() const override
Definition: item_sum.h:2003
Base class that is used to represent any kind of expression in a relational query.
Definition: item.h:929
virtual double val_real()=0
String str_value
str_values's main purpose is to cache the value in save_in_field
Definition: item.h:3669
void set_nullable(bool nullable)
Definition: item.h:3781
bool get_datetime_from_numeric(Datetime_val *dt, my_time_flags_t flags)
Convert a numeric type to datetime.
Definition: item.cc:1705
DTCollation collation
Character set and collation properties assigned for this Item.
Definition: item.h:3676
bool get_date_from_int(Date_val *date, my_time_flags_t flags)
Convert val_int() to date.
Definition: item.cc:1653
void set_data_type(enum_field_types data_type)
Set the data type of the current Item.
Definition: item.h:1513
my_decimal * val_decimal_from_string(my_decimal *decimal_value)
Definition: item.cc:390
bool is_nullable() const
Definition: item.h:3780
void set_data_type_geometry()
Set the data type of the Item to be GEOMETRY.
Definition: item.h:1755
bool get_time_from_decimal(Time_val *time)
Convert val_decimal() to time.
Definition: item.cc:1777
void set_data_type_double()
Set the data type of the Item to be double precision floating point.
Definition: item.h:1579
bool get_time_from_numeric(Time_val *time)
Convert a numeric type to time.
Definition: item.cc:1807
Item_name_string item_name
Name from query.
Definition: item.h:3677
bool fixed
True if item has been resolved.
Definition: item.h:3769
virtual Item_result result_type() const
Definition: item.h:1451
bool null_value
True if item is null.
Definition: item.h:3806
Type
Definition: item.h:964
@ SUM_FUNC_ITEM
A grouped aggregate function, or window function.
Definition: item.h:968
@ AGGR_FIELD_ITEM
A special field for certain aggregate operations.
Definition: item.h:969
bool get_datetime_from_string(Datetime_val *dt, my_time_flags_t flags)
Convert val_str() to datetime.
Definition: item.cc:1605
bool get_datetime_from_int(Datetime_val *dt, my_time_flags_t flags)
Convert val_int() to datetime.
Definition: item.cc:1647
bool get_datetime_from_real(Datetime_val *dt, my_time_flags_t flags)
Convert val_real() to datetime.
Definition: item.cc:1627
virtual TYPELIB * get_typelib() const
Get the typelib information for an item of type set or enum.
Definition: item.h:1822
my_decimal * val_decimal_from_real(my_decimal *decimal_value)
Definition: item.cc:371
bool get_date_from_real(Date_val *date, my_time_flags_t flags)
Convert val_real() to date.
Definition: item.cc:1621
bool get_time_from_int(Time_val *time)
Convert val_int() to time.
Definition: item.cc:1784
bool unsigned_flag
Definition: item.h:3807
bool get_date_from_string(Date_val *date, my_time_flags_t flags)
Convert val_str() to date.
Definition: item.cc:1613
longlong val_int_from_string()
Definition: item.cc:541
void set_grouping_func()
Set the property: this item is a call to GROUPING.
Definition: item.h:3586
bool get_time_from_real(Time_val *time)
Convert val_real() to time.
Definition: item.cc:1771
virtual bool mark_field_in_map(uchar *arg)
Mark underlying field in read or write map of a table.
Definition: item.h:2919
bool hidden
If the item is in a SELECT list (Query_block::fields) and hidden is true, the item wasn't actually in...
Definition: item.h:3817
void set_data_type_from_item(const Item *item)
Set data type properties of the item from the properties of another item.
Definition: item.h:1799
bool get_datetime_from_decimal(Datetime_val *dt, my_time_flags_t flags)
Convert val_decimal() to datetime.
Definition: item.cc:1640
bool get_date_from_numeric(Date_val *date, my_time_flags_t flags)
Convert a numeric type to date.
Definition: item.cc:1689
bool get_date_from_decimal(Date_val *date, my_time_flags_t flags)
Convert val_decimal() to date.
Definition: item.cc:1633
void set_data_type_longlong()
Set the data type of the Item to be longlong.
Definition: item.h:1555
double val_real_from_string()
Definition: item.cc:491
bool update_null_value()
Make sure the null_value member has a correct value.
Definition: item.cc:8021
bool get_time_from_string(Time_val *time)
Convert val_str() to time.
Definition: item.cc:1763
String * val_string_from_real(String *str)
Definition: item.cc:292
Represents a JSON array container, i.e.
Definition: json_dom.h:520
Represents a JSON container value of type "object" (ECMA), type J_OBJECT here.
Definition: json_dom.h:374
bool add_alias(std::string_view key, Json_dom *value)
Insert the value into the object.
Definition: json_dom.h:416
Abstraction for accessing JSON values irrespective of whether they are (started out as) binary JSON v...
Definition: json_dom.h:1268
Definition: sql_list.h:494
A typesafe replacement for DYNAMIC_ARRAY.
Definition: mem_root_array.h:432
Wrapper class for an Item list head, used to allocate Item lists in the parser in a context-independe...
Definition: parse_tree_helpers.h:109
Definition: parse_tree_nodes.h:234
Parse tree node for a window; just a shallow wrapper for class Window, q.v.
Definition: parse_tree_window.h:39
void error(Context *pc, const POS &pos) const
syntax_error() function replacement for deferred reporting of syntax errors
Definition: parse_tree_node_base.h:346
This class represents a query block, aka a query specification, which is a query consisting of a SELE...
Definition: sql_lex.h:1179
Using this class is fraught with peril, and you need to be very careful when doing so.
Definition: sql_string.h:169
const CHARSET_INFO * charset() const
Definition: sql_string.h:242
const char * ptr() const
Definition: sql_string.h:251
size_t length() const
Definition: sql_string.h:243
void set(String &str, size_t offset, size_t arg_length)
Definition: sql_string.h:304
For each client connection we create a separate thread with THD serving as a thread/connection descri...
Definition: sql_lexer_thd.h:36
Object containing parameters used when creating and using temporary tables.
Definition: temp_table_param.h:97
Time_val is a temporal type that represents only time.
Definition: my_temporal.h:57
Unique – class for unique (removing of duplicates).
Definition: uniques.h:53
Represents the (explicit) window of a SQL 2003 section 7.11 <window clause>, or the implicit (inlined...
Definition: window.h:110
uint size() const
Definition: sql_list.h:326
A (partial) implementation of std::deque allocating its blocks on a MEM_ROOT.
Definition: mem_root_deque.h:172
my_decimal class limits 'decimal_t' type to what we need in MySQL.
Definition: my_decimal.h:97
const char * name() const
Definition: sql_udf.h:118
bool is_initialized() const
Definition: sql_udf.h:116
bool m_original
Definition: sql_udf.h:105
bool fix_fields(THD *thd, Item_result_field *item, uint arg_count, Item **args)
Definition: item_func.cc:4879
void free_handler()
Definition: item_func.cc:4860
enum_query_type
Query type constants (usable as bitmap flags).
Definition: enum_query_type.h:31
This file contains the field type.
enum_field_types
Column types for MySQL Note: Keep include/mysql/components/services/bits/stored_program_bits....
Definition: field_types.h:55
@ MYSQL_TYPE_LONGLONG
Definition: field_types.h:64
@ MYSQL_TYPE_NEWDECIMAL
Definition: field_types.h:81
@ MYSQL_TYPE_DOUBLE
Definition: field_types.h:61
static const std::string dec("DECRYPTION")
This file declares the coordinate system specific subclasses of the geometry class hierarchy.
void my_error(int nr, myf MyFlags,...)
Fill in and print a previously registered error message.
Definition: my_error.cc:217
static int flags[50]
Definition: hp_test1.cc:40
static uint16 key1[1001]
Definition: hp_test2.cc:50
int dump_leaf_key(void *key_arg, element_count count, void *item_arg)
Append data from current leaf to item->result.
Definition: item_sum.cc:4307
int group_concat_key_cmp_with_distinct(const void *arg, const void *key1, const void *key2)
Compares the values for fields in expr list of GROUP_CONCAT.
Definition: item_sum.cc:4228
int group_concat_key_cmp_with_order(const void *arg, const void *key1, const void *key2)
function of sort for syntax: GROUP_CONCAT(expr,... ORDER BY col,... )
Definition: item_sum.cc:4264
Json_constructor_null_clause
Definition: item_sum.h:1235
A better implementation of the UNIX ctype(3) library.
MYSQL_STRINGS_EXPORT CHARSET_INFO my_charset_bin
Definition: ctype-bin.cc:499
double my_strntod(const CHARSET_INFO *cs, const char *str, size_t length, const char **end, int *err)
Definition: m_ctype.h:759
This file follows Google coding style, except for the name MEM_ROOT (which is kept for historical rea...
std::unique_ptr< T, Destroy_only< T > > unique_ptr_destroy_only
std::unique_ptr, but only destroying.
Definition: my_alloc.h:480
Header for compiler-dependent features.
It is interface module to fixed precision decimals library.
Some integer typedefs for easier portability.
unsigned long long int ulonglong
Definition: my_inttypes.h:56
unsigned char uchar
Definition: my_inttypes.h:52
int64_t int64
Definition: my_inttypes.h:68
long long int longlong
Definition: my_inttypes.h:55
int8_t int8
Definition: my_inttypes.h:62
#define MYF(v)
Definition: my_inttypes.h:97
uint64_t uint64
Definition: my_inttypes.h:69
uint32_t uint32
Definition: my_inttypes.h:67
MYSQL_STRINGS_EXPORT long long my_strtoll10(const char *nptr, const char **endptr, int *error)
Definition: my_strtoll10.cc:87
Common header for many mysys elements.
uint64_t nesting_map
Definition: my_table_map.h:31
uint64_t table_map
Definition: my_table_map.h:30
Interface for low level time utilities.
unsigned int my_time_flags_t
Flags to str_to_datetime and int_to_datetime.
Definition: my_time.h:87
uint32 element_count
Definition: my_tree.h:52
static int count
Definition: myisam_ftdump.cc:45
thread_local MEM_ROOT ** THR_MALLOC
Definition: mysqld.cc:1593
std::string str(const mysqlrouter::ConfigGenerator::Options::Endpoint &ep)
Definition: config_generator.cc:1077
static PFS_engine_table_share_proxy table
Definition: pfs.cc:61
Definition: commit_order_queue.h:34
PT & ref(PT *tp)
Definition: tablespace_impl.cc:359
ValueType value(const std::optional< ValueType > &v)
Definition: gtid.h:83
noexcept
The return type for any call_and_catch(f, args...) call where f(args...) returns Type.
Definition: call_and_catch.h:76
size_t size(const char *const c)
Definition: base64.h:46
mutable_buffer buffer(void *p, size_t n) noexcept
Definition: buffer.h:418
Cursor end()
A past-the-end Cursor.
Definition: rules_table_service.cc:192
std::list< T, ut::allocator< T > > list
Specialization of list which uses ut_allocator.
Definition: ut0new.h:2884
const mysql_service_registry_t * r
Definition: pfs_example_plugin_employee.cc:86
File containing constants that can be used throughout the server.
constexpr const size_t STRING_BUFFER_USUAL_SIZE
Definition: sql_const.h:126
Our own string classes, used pervasively throughout the executor.
Definition: m_ctype.h:421
Struct used to pass around arguments to/from check_function_as_value_generator.
Definition: item.h:487
int err_code
the error code found during check(if any)
Definition: item.h:494
int get_unnamed_function_error_code() const
Return the correct error code, based on whether or not if we are checking for disallowed functions in...
Definition: item.h:506
argument used by walk method collect_grouped_aggregates ("cga")
Definition: item_sum.h:625
Collect_grouped_aggregate_info(Query_block *select)
Definition: item_sum.h:638
Query_block * m_query_block
The query block we walk from.
Definition: item_sum.h:633
std::vector< Item_sum * > list
accumulated all aggregates found
Definition: item_sum.h:627
std::set< Item_sum * > aggregates_that_were_hidden
Definition: item_sum.h:628
bool m_break_off
true: break off transformation
Definition: item_sum.h:635
bool m_outside
true: an aggregate aggregates outside m_query_block
Definition: item_sum.h:637
Bison "location" class.
Definition: parse_location.h:43
Instances of Name_resolution_context store the information necessary for name resolution of Items and...
Definition: item.h:414
Environment data for the contextualization phase.
Definition: parse_tree_node_base.h:422
Collects evaluation requirements from a window function, used by Item_sum::check_wf_semantics and its...
Definition: window.h:1556
Item_result
Type of the user defined function return slot and arguments.
Definition: udf_registration_types.h:39
@ STRING_RESULT
not valid for UDFs
Definition: udf_registration_types.h:41
@ DECIMAL_RESULT
not valid for UDFs
Definition: udf_registration_types.h:45
@ REAL_RESULT
char *
Definition: udf_registration_types.h:42
@ INT_RESULT
double
Definition: udf_registration_types.h:43
@ INVALID_RESULT
Definition: udf_registration_types.h:40
enum_null_treatment
Cf.
Definition: window_lex.h:58
This file declares the interface of the WKB parser for geometries and the parser for the internal geo...