diff options
Diffstat (limited to 'sql/sql_truncate.cc')
| -rw-r--r-- | sql/sql_truncate.cc | 23 | 
1 files changed, 13 insertions, 10 deletions
| diff --git a/sql/sql_truncate.cc b/sql/sql_truncate.cc index c3d347307a2..e7ecdda958e 100644 --- a/sql/sql_truncate.cc +++ b/sql/sql_truncate.cc @@ -416,20 +416,23 @@ bool Sql_cmd_truncate_table::truncate_table(THD *thd, TABLE_LIST *table_ref)      bool hton_can_recreate;  #ifdef WITH_WSREP -    if (WSREP(thd)) +    if (WSREP(thd) && wsrep_thd_is_local(thd))      {        wsrep::key_array keys; -      wsrep_append_fk_parent_table(thd, table_ref, &keys); -      if (keys.empty()) +      /* Do not start TOI if table is not found */ +      if (!wsrep_append_fk_parent_table(thd, table_ref, &keys))        { -        WSREP_TO_ISOLATION_BEGIN_IF(table_ref->db.str, table_ref->table_name.str, NULL) +        if (keys.empty())          { -          DBUG_RETURN(TRUE); -        } -      } else { -        WSREP_TO_ISOLATION_BEGIN_FK_TABLES(NULL, NULL, table_ref, &keys) -        { -          DBUG_RETURN(TRUE); +          WSREP_TO_ISOLATION_BEGIN_IF(table_ref->db.str, table_ref->table_name.str, NULL) +          { +            DBUG_RETURN(TRUE); +          } +        } else { +          WSREP_TO_ISOLATION_BEGIN_FK_TABLES(NULL, NULL, table_ref, &keys) +          { +            DBUG_RETURN(TRUE); +          }          }        }      } | 
