• unknown's avatar
    Implementation of WL#1469 (Greedy algorithm to search for an optimal execution plan). · 4c56ede4
    unknown authored
    mysql-test/r/subselect.result:
      Table pre-sorting before optimization makes the optimizer select a different plan, this change fixes the plan.
    sql/mysql_priv.h:
      Added new status variable last_query_cost that contains the cost of the last compiled query.
    sql/mysqld.cc:
      * Added new system variable 'plan_search_depth' to control the exhaustiveness of the search for an optimal query plan.
      * Added new system variable 'heuristic' to control the use of query optimization heuristic.
      * Added new status variable 'last_query_cost' that contains the cost of the last compiled query.
    sql/set_var.cc:
      * Added new system variable 'plan_search_depth' to control the exhaustiveness of the search for an optimal query plan.
      * Added new system variable 'heuristic' to control the use of query optimization heuristic.
    sql/sql_class.h:
      * Added new system variable 'plan_search_depth' to control the exhaustiveness of the search for an optimal query plan.
      * Added new system variable 'heuristic' to control the use of query optimization heuristic.
    sql/sql_select.cc:
      Added a combined greedy/exhaustive query optimization algorithm.
      * The greedy search algorithm is implemented in function 'greedy_search'.
      * The exhaustive search with controlled search depth is implemented in function 'find_best_limited_depth', a modification of 'find_best'.
      * The selection of the best access path and its cost computation is factored out from 'find_best' into function 'best_access_path'.
      * In addition:
        - added pre-sorting for the query tables before they get optimized
        - factored out the optimization of STRAIGHT_JOIN into a separate procedure
    sql/sql_select.h:
      Added new field to st_position to support the greedy optimizer.
      Added a comment to class JOIN.
    sql/sql_show.cc:
      Added a case to 'mysqld_show' to print double status variables.
    sql/structs.h:
      Added a new type of status variables SHOW_DOUBLE
    BitKeeper/etc/logging_ok:
      Logging to logging@openlogging.org accepted
    4c56ede4
greedy_optimizer.test 20.4 KB