summaryrefslogtreecommitdiff
path: root/sql/sql_union.cc
diff options
context:
space:
mode:
authorunknown <Sinisa@sinisa.nasamreza.org>2003-04-21 21:03:32 +0300
committerunknown <Sinisa@sinisa.nasamreza.org>2003-04-21 21:03:32 +0300
commit8078280c7664a385bccdf394f4927474ef738d98 (patch)
tree7a08a3618a847d9c0596c98295a731eff9e349b0 /sql/sql_union.cc
parentfa741bbc0316e9bdaeb1c3af416ed3dcf41b021f (diff)
downloadmariadb-git-8078280c7664a385bccdf394f4927474ef738d98.tar.gz
Fix for a bug record #307.
Very nasty bug. It was caused by double free()-ing memory of join->select and join->quick. I was able to pinpoint it only after using Valgrind. Plus better fix for bug with TMP_TABLE_PARAM. Plus new constructor for SELECT_LEX. mysql-test/r/innodb.result: Fix for a bug record #307. Very nasty bug. It was caused by double free()-ing memory of join->select and join->quick. I was able to pinpoint it only after using Valgrind. mysql-test/t/innodb.test: Fix for a bug record #307. Very nasty bug. It was caused by double free()-ing memory of join->select and join->quick. I was able to pinpoint it only after using Valgrind. sql/sql_lex.cc: Adding a usefull constructor sql/sql_lex.h: Adding a usefull constructor which additionally required few more definitions. sql/sql_select.cc: Fix for a bug record #307. Very nasty bug. It was caused by double free()-ing memory of join->select and join->quick. I was able to pinpoint it only after using Valgrind. sql/sql_union.cc: Fixing bug #307. Also, a better fix for TMP_TABLE_PARAM bug. Also, use of the new constructor for SELECT_LEX.
Diffstat (limited to 'sql/sql_union.cc')
-rw-r--r--sql/sql_union.cc20
1 files changed, 9 insertions, 11 deletions
diff --git a/sql/sql_union.cc b/sql/sql_union.cc
index 594eac2c942..48f536c68cf 100644
--- a/sql/sql_union.cc
+++ b/sql/sql_union.cc
@@ -124,10 +124,11 @@ int st_select_lex_unit::prepare(THD *thd, select_result *sel_result,
prepared= 1;
res= 0;
found_rows_for_union= 0;
- TMP_TABLE_PARAM *tmp_table_param= (TMP_TABLE_PARAM *)sql_calloc(sizeof(TMP_TABLE_PARAM));
+ TMP_TABLE_PARAM tmp_table_param;
result= sel_result;
t_and_f= tables_and_fields_initied;
-
+
+ bzero((char *)&tmp_table_param,sizeof(TMP_TABLE_PARAM));
thd->lex.current_select= select_cursor= first_select_in_union();
/* Global option */
if (((void*)(global_parameters)) == ((void*)this))
@@ -167,8 +168,8 @@ int st_select_lex_unit::prepare(THD *thd, select_result *sel_result,
t_and_f= 1;
}
- tmp_table_param->field_count=item_list.elements;
- if (!(table= create_tmp_table(thd, tmp_table_param, item_list,
+ tmp_table_param.field_count=item_list.elements;
+ if (!(table= create_tmp_table(thd, &tmp_table_param, item_list,
(ORDER*) 0, !union_option,
1, (select_cursor->options | thd->options |
TMP_TABLE_ALL_COLUMNS),
@@ -185,7 +186,8 @@ int st_select_lex_unit::prepare(THD *thd, select_result *sel_result,
goto err;
union_result->not_describe=1;
- union_result->tmp_table_param=tmp_table_param;
+ if (!(union_result->tmp_table_param=(TMP_TABLE_PARAM *)thd->memdup((char *)&tmp_table_param, sizeof(TMP_TABLE_PARAM))))
+ goto err;
/*
The following piece of code is placed here solely for the purpose of
@@ -250,11 +252,9 @@ int st_select_lex_unit::exec()
{
int do_print_slow= 0;
SELECT_LEX_NODE *lex_select_save= thd->lex.current_select;
- SELECT_LEX *select_cursor=first_select_in_union(), *last_select;
+ SELECT_LEX *select_cursor=first_select_in_union();
DBUG_ENTER("st_select_lex_unit::exec");
- LINT_INIT(last_select);
-
if (executed && !(dependent || uncacheable))
DBUG_RETURN(0);
executed= 1;
@@ -269,7 +269,6 @@ int st_select_lex_unit::exec()
}
for (SELECT_LEX *sl= select_cursor; sl; sl= sl->next_select())
{
- last_select=sl;
if (optimized)
res= sl->join->reinit();
else
@@ -335,8 +334,7 @@ int st_select_lex_unit::exec()
if (!thd->is_fatal_error) // Check if EOM
{
- SELECT_LEX *fake_select = new SELECT_LEX();
- fake_select->make_empty_select(last_select);
+ SELECT_LEX *fake_select = new SELECT_LEX(&thd->lex);
offset_limit_cnt= (select_cursor->braces ?
global_parameters->offset_limit : 0);
select_limit_cnt= (select_cursor->braces ?