summaryrefslogtreecommitdiff
path: root/storage/innobase/row/row0vers.cc
diff options
context:
space:
mode:
authorMarko Mäkelä <marko.makela@mariadb.com>2018-08-23 13:11:11 +0300
committerMarko Mäkelä <marko.makela@mariadb.com>2018-08-23 13:11:11 +0300
commit9a815401c6c1972745432ff93cbc8f55cae30d0f (patch)
treedb8bb358cf556ff98760fb3349ce8ce1c4ce9d52 /storage/innobase/row/row0vers.cc
parent5d650d366dbcbd49679bf8b0884b63056053fb44 (diff)
downloadmariadb-git-9a815401c6c1972745432ff93cbc8f55cae30d0f.tar.gz
MDEV-17043 Purge of indexed virtual columns may cause hang on table-rebuilding DDL
When a table is renamed to an internal #sql2 or #sql-ib name during a table-rebuilding DDL operation such as OPTIMIZE TABLE or ALTER TABLE, and shortly after that a purge operation in an index on virtual columns is attempted, the operation could fail, but purge would fail to release the table reference. innodb_acquire_mdl(): Release the reference if the table name is not valid for acquiring a meta-data lock (MDL). innodb_find_table_for_vc(): Add a debug assertion if the table name is not valid. This code path is for DML execution. The table should have a valid name for executing DML, and furthermore a MDL will prevent the table from being renamed. row_vers_build_clust_v_col(): Add a debug assertion that both indexes must belong to the same table.
Diffstat (limited to 'storage/innobase/row/row0vers.cc')
-rw-r--r--storage/innobase/row/row0vers.cc1
1 files changed, 1 insertions, 0 deletions
diff --git a/storage/innobase/row/row0vers.cc b/storage/innobase/row/row0vers.cc
index 24acd04c84b..811654fdef8 100644
--- a/storage/innobase/row/row0vers.cc
+++ b/storage/innobase/row/row0vers.cc
@@ -456,6 +456,7 @@ row_vers_build_clust_v_col(
byte* record= 0;
ut_ad(dict_index_has_virtual(index));
+ ut_ad(index->table == clust_index->table);
if (vcol_info != NULL) {
vcol_info->set_used();