summaryrefslogtreecommitdiff
path: root/sql/sql_derived.cc
diff options
context:
space:
mode:
authorunknown <Sinisa@sinisa.nasamreza.org>2003-07-19 18:49:04 +0300
committerunknown <Sinisa@sinisa.nasamreza.org>2003-07-19 18:49:04 +0300
commit5dadac8701ae9cd464b052f03137117e71983072 (patch)
tree19379b85309c32c2bd61dc6cde7d76ea08547ee9 /sql/sql_derived.cc
parent00e8a411510604f1dd9a9bdbf82b76423757dc69 (diff)
parent8f5bdb0000342c0b5380a4b754413a364f42a433 (diff)
downloadmariadb-git-5dadac8701ae9cd464b052f03137117e71983072.tar.gz
Merge
mysql-test/r/innodb.result: Auto merged sql/ha_myisam.cc: Auto merged sql/sql_base.cc: Auto merged sql/sql_derived.cc: Auto merged sql/sql_table.cc: Auto merged sql/sql_union.cc: Auto merged sql/table.h: Auto merged
Diffstat (limited to 'sql/sql_derived.cc')
-rw-r--r--sql/sql_derived.cc10
1 files changed, 10 insertions, 0 deletions
diff --git a/sql/sql_derived.cc b/sql/sql_derived.cc
index c61e8f42343..470bffe56d9 100644
--- a/sql/sql_derived.cc
+++ b/sql/sql_derived.cc
@@ -122,6 +122,16 @@ int mysql_derived(THD *thd, LEX *lex, SELECT_LEX_UNIT *unit,
res= -1;
goto exit;
}
+
+ /*
+ This is done in order to redo all field optimisations when any of the
+ involved tables is used in the outer query
+ */
+ if (tables)
+ {
+ for (TABLE_LIST *cursor= tables; cursor; cursor= cursor->next)
+ cursor->table->clear_query_id= 1;
+ }
item_list= select_cursor->item_list;
select_cursor->with_wild= 0;