Commit 7e03ac49 authored by marko's avatar marko

branches/innodb+: row_ins_index_entry_low(): Do not attempt to buffer

inserts into the clustered index, so that the ut_ad() introduced in
r3475 will not fail.
parent 49e36855
...@@ -1998,7 +1998,7 @@ row_ins_index_entry_low( ...@@ -1998,7 +1998,7 @@ row_ins_index_entry_low(
que_thr_t* thr) /* in: query thread */ que_thr_t* thr) /* in: query thread */
{ {
btr_cur_t cursor; btr_cur_t cursor;
ulint ignore_sec_unique = 0; ulint search_mode;
ulint modify = 0; /* remove warning */ ulint modify = 0; /* remove warning */
rec_t* insert_rec; rec_t* insert_rec;
rec_t* rec; rec_t* rec;
...@@ -2018,18 +2018,22 @@ row_ins_index_entry_low( ...@@ -2018,18 +2018,22 @@ row_ins_index_entry_low(
the function will return in both low_match and up_match of the the function will return in both low_match and up_match of the
cursor sensible values */ cursor sensible values */
if (!(thr_get_trx(thr)->check_unique_secondary)) { if (dict_index_is_clust(index)) {
ignore_sec_unique = BTR_IGNORE_SEC_UNIQUE; search_mode = mode;
} else if (!(thr_get_trx(thr)->check_unique_secondary)) {
search_mode = mode | BTR_INSERT | BTR_IGNORE_SEC_UNIQUE;
} else {
search_mode = mode | BTR_INSERT;
} }
btr_cur_search_to_nth_level(index, 0, entry, PAGE_CUR_LE, btr_cur_search_to_nth_level(index, 0, entry, PAGE_CUR_LE,
mode | BTR_INSERT | ignore_sec_unique, search_mode, &cursor, 0, &mtr);
&cursor, 0, &mtr);
if (cursor.flag == BTR_CUR_INSERT_TO_IBUF) { if (cursor.flag == BTR_CUR_INSERT_TO_IBUF) {
/* The insertion was made to the insert buffer already during /* The insertion was made to the insert buffer already during
the search: we are done */ the search: we are done */
ut_ad(search_mode & BTR_INSERT);
err = DB_SUCCESS; err = DB_SUCCESS;
goto function_exit; goto function_exit;
......
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