diff options
-rw-r--r-- | sql/sql_base.cc | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/sql/sql_base.cc b/sql/sql_base.cc index e7bb9a778e2..e77e65b77cc 100644 --- a/sql/sql_base.cc +++ b/sql/sql_base.cc @@ -2290,16 +2290,20 @@ insert_fields(THD *thd,TABLE_LIST *tables, const char *db_name, DBUG_RETURN(-1); #endif Field **ptr=table->field,*field; + TABLE *natural_join_table; thd->used_tables|=table->map; + if (table->outer_join || + !tables->natural_join || + tables->natural_join->table->outer_join) + natural_join_table= NULL; + else + natural_join_table= tables->natural_join->table; while ((field = *ptr++)) { /* Skip duplicate field names if NATURAL JOIN is used */ - if (table->outer_join || - !tables->natural_join || - tables->natural_join->table->outer_join || - !find_field_in_table(thd, tables->natural_join->table, - field->field_name, strlen(field->field_name), - 0, 0)) + if (!natural_join_table || + !find_field_in_table(thd, natural_join_table, field->field_name, + strlen(field->field_name), 0, 0)) { Item_field *item= new Item_field(field); if (!found++) |