backport of ndb DictCache fix

- don't invalidate tables that are in state RETRIEVING
parent 9f542ef0
...@@ -278,6 +278,8 @@ GlobalDictCache::invalidate_all() ...@@ -278,6 +278,8 @@ GlobalDictCache::invalidate_all()
if (vers->size()) if (vers->size())
{ {
TableVersion * ver = & vers->back(); TableVersion * ver = & vers->back();
if (ver->m_status != RETREIVING)
{
ver->m_impl->m_status = NdbDictionary::Object::Invalid; ver->m_impl->m_status = NdbDictionary::Object::Invalid;
ver->m_status = DROPPED; ver->m_status = DROPPED;
if (ver->m_refCount == 0) if (ver->m_refCount == 0)
...@@ -286,6 +288,7 @@ GlobalDictCache::invalidate_all() ...@@ -286,6 +288,7 @@ GlobalDictCache::invalidate_all()
vers->erase(vers->size() - 1); vers->erase(vers->size() - 1);
} }
} }
}
curr = m_tableHash.getNext(curr); curr = m_tableHash.getNext(curr);
} }
DBUG_VOID_RETURN; DBUG_VOID_RETURN;
......
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