• unknown's avatar
    Fixed bug#19862: Sort with filesort by function evaluates function twice · 9a63adc8
    unknown authored
    When there is no index defined filesort is used to sort the result of a
    query. If there is a function in the select list and the result set should be
    ordered by it's value then this function will be evaluated twice. First time to
    get the value of the sort key and second time to send its value to a user.
    This happens because filesort when sorts a table remembers only values of its
    fields but not values of functions.
    All functions are affected. But taking into account that SP and UDF functions
    can be both expensive and non-deterministic a temporary table should be used 
    to store their results and then sort it to avoid twice SP evaluation and to 
    get a correct result.
    
    If an expression referenced in an ORDER clause contains a SP or UDF 
    function, force the use of a temporary table.
    
    A new Item_processor function called func_type_checker_processor is added
    to check whether the expression contains a function of a particular type.
    
    
    mysql-test/t/udf.test:
      Added test case for bug#19862: Sort with filesort by function evaluates function twice
    mysql-test/t/sp.test:
      Added test case for bug#19862: Sort with filesort by function evaluates function twice
    mysql-test/r/sp.result:
      Added test case for bug#19862: Sort with filesort by function evaluates function twice
    mysql-test/r/udf.result:
      Added test case for bug#19862: Sort with filesort by function evaluates function twice
    sql/sql_select.cc:
      Fixed bug#19862: Sort with filesort by function evaluates function twice
      If an expression referenced in an ORDER clause contains a SP or UDF
      function, force the use of a temporary table.
    sql/item_func.h:
      Fixed bug#19862: Sort with filesort by function evaluates function twice
      A new Item_processor function called func_type_checker_processor is added
      to check whether the expression contains a function of a particular type.
    sql/item.h:
      Fixed bug#19862: Sort with filesort by function evaluates function twice
      A new Item_processor function called func_type_checker_processor is added
      to check whether the expression contains a function of a particular type.
    sql/item_func.cc:
      Fixed bug#19862: Sort with filesort by function evaluates function twice
      A new Item_processor function called func_type_checker_processor is added
      to check whether the expression contains a function of a particular type.
    9a63adc8
udf.result 3.07 KB