Commit 66ea81cd authored by Mikael Ronstrom's avatar Mikael Ronstrom

BUG#47752, missed to sort values in list partitioning

parent dc97402c
...@@ -993,15 +993,16 @@ bool partition_info::check_list_constants(THD *thd) ...@@ -993,15 +993,16 @@ bool partition_info::check_list_constants(THD *thd)
} }
} while (++i < num_parts); } while (++i < num_parts);
} }
if (fixed && num_list_values) DBUG_ASSERT(fixed);
if (num_list_values)
{ {
bool first= TRUE; bool first= TRUE;
/* /*
list_array and list_col_array are unions, so this works for both list_array and list_col_array are unions, so this works for both
variants of LIST partitioning. variants of LIST partitioning.
*/ */
my_qsort((void*)list_array, num_list_values, sizeof(LIST_PART_ENTRY), my_qsort((void*)list_array, num_list_values, size_entries,
&list_part_cmp); compare_func);
i= 0; i= 0;
LINT_INIT(prev_value); LINT_INIT(prev_value);
......
...@@ -1030,8 +1030,6 @@ static bool fix_fields_part_func(THD *thd, Item* func_expr, TABLE *table, ...@@ -1030,8 +1030,6 @@ static bool fix_fields_part_func(THD *thd, Item* func_expr, TABLE *table,
if ((!is_sub_part) && (error= check_signed_flag(part_info))) if ((!is_sub_part) && (error= check_signed_flag(part_info)))
goto end; goto end;
result= set_up_field_array(table, is_sub_part); result= set_up_field_array(table, is_sub_part);
if (!is_sub_part)
part_info->fixed= TRUE;
end: end:
table->get_fields_in_item_tree= FALSE; table->get_fields_in_item_tree= FALSE;
table->map= 0; //Restore old value table->map= 0; //Restore old value
...@@ -1667,6 +1665,7 @@ bool fix_partition_func(THD *thd, TABLE *table, ...@@ -1667,6 +1665,7 @@ bool fix_partition_func(THD *thd, TABLE *table,
} }
part_info->part_result_type= INT_RESULT; part_info->part_result_type= INT_RESULT;
} }
part_info->fixed= TRUE;
} }
else else
{ {
...@@ -1683,6 +1682,7 @@ bool fix_partition_func(THD *thd, TABLE *table, ...@@ -1683,6 +1682,7 @@ bool fix_partition_func(THD *thd, TABLE *table,
table, FALSE))) table, FALSE)))
goto end; goto end;
} }
part_info->fixed= TRUE;
if (part_info->part_type == RANGE_PARTITION) if (part_info->part_type == RANGE_PARTITION)
{ {
error_str= partition_keywords[PKW_RANGE].str; error_str= partition_keywords[PKW_RANGE].str;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment