summaryrefslogtreecommitdiff
path: root/sql/item_windowfunc.cc
diff options
context:
space:
mode:
authorVarun Gupta <varunraiko1803@gmail.com>2017-09-07 17:40:09 +0530
committerVarun Gupta <varunraiko1803@gmail.com>2017-11-01 23:17:14 +0530
commit02a4a4b512ace75bbe66065c136d697e83a4d9ff (patch)
treeb84f113b206a752c2ec7d4f2b674995a0362c662 /sql/item_windowfunc.cc
parentb5c104d00a264e250cc008c6f2a42e8a2b18f385 (diff)
downloadmariadb-git-02a4a4b512ace75bbe66065c136d697e83a4d9ff.tar.gz
Added fix_fields for percentile function to check the type of argument and to ensure that only numeric arguments are allowed
Diffstat (limited to 'sql/item_windowfunc.cc')
-rw-r--r--sql/item_windowfunc.cc54
1 files changed, 43 insertions, 11 deletions
diff --git a/sql/item_windowfunc.cc b/sql/item_windowfunc.cc
index 4022c3ddf70..f941900646e 100644
--- a/sql/item_windowfunc.cc
+++ b/sql/item_windowfunc.cc
@@ -109,15 +109,6 @@ Item_window_func::fix_fields(THD *thd, Item **ref)
return true;
}
- if (only_single_element_order_list())
- {
- if (window_spec->order_list->elements != 1)
- {
- my_error(ER_NOT_SINGLE_ELEMENT_ORDER_LIST, MYF(0), window_func()->func_name());
- return true;
- }
- }
-
/*
TODO: why the last parameter is 'ref' in this call? What if window_func
decides to substitute itself for something else and does *ref=.... ?
@@ -182,9 +173,11 @@ bool Item_window_func::check_result_type_of_order_item()
{
if (only_single_element_order_list())
{
- Item_result rtype= window_spec->order_list->first->item[0]->result_type();
+ Item_result rtype= window_spec->order_list->first->item[0]->cmp_type();
+ // TODO (varun) : support date type in percentile_cont function
if (rtype != REAL_RESULT && rtype != INT_RESULT &&
- rtype != DECIMAL_RESULT && window_func()->sum_func() == Item_sum::PERCENTILE_CONT_FUNC)
+ rtype != DECIMAL_RESULT && rtype != TIME_RESULT
+ window_func()->sum_func() == Item_sum::PERCENTILE_CONT_FUNC)
{
my_error(ER_WRONG_TYPE_FOR_PERCENTILE_CONT, MYF(0));
return TRUE;
@@ -243,6 +236,45 @@ void Item_sum_percentile_cont::setup_window_func(THD *thd, Window_spec *window_s
floor_value->setup(thd, order_item);
floor_value->store(order_item);
}
+bool Item_sum_percentile_cont::fix_fields(THD *thd, Item **ref)
+{
+ bool res;
+ res= Item_sum_num::fix_fields(thd, ref);
+ if (res)
+ return res;
+
+ switch(args[0]->cmp_type())
+ {
+ case DECIMAL_RESULT:
+ case REAL_RESULT:
+ case INT_RESULT:
+ break;
+ default:
+ my_error(ER_WRONG_TYPE_OF_ARGUMENT, MYF(0));
+ return TRUE;
+ }
+ return res;
+}
+bool Item_sum_percentile_disc::fix_fields(THD *thd, Item **ref)
+{
+ bool res;
+ res= Item_sum_num::fix_fields(thd, ref);
+ if (res)
+ return res;
+
+ switch(args[0]->cmp_type())
+ {
+ case DECIMAL_RESULT:
+ case REAL_RESULT:
+ case INT_RESULT:
+ break;
+ default:
+ my_error(ER_WRONG_TYPE_OF_ARGUMENT, MYF(0));
+ return TRUE;
+ }
+ return res;
+
+}
bool Item_sum_dense_rank::add()
{