Commit 6690972b authored by marko's avatar marko

branches/zip: Fast index creation: Clarify why lock waits may occur in

row_merge_lock_table().

ha_innobase::final_drop_index(): Set the dictionary operation mode to
TRX_DICT_OP_INDEX_MAY_WAIT for the duration of the row_merge_lock_table()
call.
parent da1e0d7f
...@@ -701,7 +701,9 @@ err_exit: ...@@ -701,7 +701,9 @@ err_exit:
/* Flag this transaction as a dictionary operation, so that /* Flag this transaction as a dictionary operation, so that
the data dictionary will be locked in crash recovery. Prevent the data dictionary will be locked in crash recovery. Prevent
warnings if row_merge_lock_table() results in a lock wait. */ warnings if row_merge_lock_table() results in a lock wait,
i.e., when another transaction is holding a conflicting lock
on the table, e.g., because of SELECT ... FOR UPDATE. */
trx_set_dict_operation(trx, TRX_DICT_OP_INDEX_MAY_WAIT); trx_set_dict_operation(trx, TRX_DICT_OP_INDEX_MAY_WAIT);
/* Acquire a lock on the table before creating any indexes. */ /* Acquire a lock on the table before creating any indexes. */
...@@ -1095,8 +1097,11 @@ ha_innobase::final_drop_index( ...@@ -1095,8 +1097,11 @@ ha_innobase::final_drop_index(
row_mysql_lock_data_dictionary(trx); row_mysql_lock_data_dictionary(trx);
/* Flag this transaction as a dictionary operation, so that /* Flag this transaction as a dictionary operation, so that
the data dictionary will be locked in crash recovery. */ the data dictionary will be locked in crash recovery. Prevent
trx_set_dict_operation(trx, TRX_DICT_OP_INDEX); warnings if row_merge_lock_table() results in a lock wait,
i.e., when another transaction is holding a conflicting lock
on the table, e.g., because of SELECT ... FOR UPDATE. */
trx_set_dict_operation(trx, TRX_DICT_OP_INDEX_MAY_WAIT);
/* Lock the table exclusively, to ensure that no active /* Lock the table exclusively, to ensure that no active
transaction depends on an index that is being dropped. */ transaction depends on an index that is being dropped. */
...@@ -1109,6 +1114,8 @@ ha_innobase::final_drop_index( ...@@ -1109,6 +1114,8 @@ ha_innobase::final_drop_index(
goto func_exit; goto func_exit;
} }
trx_set_dict_operation(trx, TRX_DICT_OP_INDEX);
index = dict_table_get_first_index(prebuilt->table); index = dict_table_get_first_index(prebuilt->table);
while (index) { while (index) {
......
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