Commit 2d4075e1 authored by Marko Mäkelä's avatar Marko Mäkelä

MDEV-17466 Virtual column value not available during purge

row_build_index_entry_low(): Assert that when the value of a
virtual column is not available, this can only happen when
the index creation was completed but not committed yet.

This change is not fixing any bug, making a debug assertion
stricter, so that bugs can be caught in the future.

Ultimately, we should change the InnoDB undo log format so that
all actual secondary index keys are stored there, also for
virtual or spatial indexes. In that way, purge and rollback would
be more straightforward.
parent af6077b5
...@@ -127,6 +127,8 @@ row_build_index_entry_low( ...@@ -127,6 +127,8 @@ row_build_index_entry_low(
ut_ad(dfield_is_null(dfield2) || ut_ad(dfield_is_null(dfield2) ||
dfield_get_len(dfield2) == 0 || dfield2->data); dfield_get_len(dfield2) == 0 || dfield2->data);
ut_ad(dfield2->type.mtype != DATA_MISSING
|| !index->is_committed());
} else { } else {
dfield2 = dtuple_get_nth_field(row, col_no); dfield2 = dtuple_get_nth_field(row, col_no);
ut_ad(dfield_get_type(dfield2)->mtype == DATA_MISSING ut_ad(dfield_get_type(dfield2)->mtype == DATA_MISSING
......
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