MDEV-33868 Assertion `trx->bulk_insert' failed in innodb_prepare_commit_versioned

- This issue is caused by commit 188c5da7 (MDEV-32453).
InnoDB fails to end the bulk insert for the table after
applying the bulk insert operation. This leads to assertion
during commit process.
parent cac0fc97
...@@ -478,4 +478,14 @@ INSERT INTO t VALUES (1),(1); ...@@ -478,4 +478,14 @@ INSERT INTO t VALUES (1),(1);
ERROR 21000: Subquery returns more than 1 row ERROR 21000: Subquery returns more than 1 row
COMMIT; COMMIT;
DROP TABLE t; DROP TABLE t;
#
# MDEV-33868 Assertion `trx->bulk_insert' failed in
# innodb_prepare_commit_versioned
#
CREATE TABLE t (id INT) ENGINE=InnoDB;
select 1 into outfile "VARDIR/tmp/t.outfile";
BEGIN;
LOAD DATA INFILE 'VARDIR/tmp/t.outfile' INTO TABLE t;
COMMIT;
DROP TABLE t;
# End of 10.11 tests # End of 10.11 tests
...@@ -507,4 +507,20 @@ BEGIN; ...@@ -507,4 +507,20 @@ BEGIN;
INSERT INTO t VALUES (1),(1); INSERT INTO t VALUES (1),(1);
COMMIT; COMMIT;
DROP TABLE t; DROP TABLE t;
--echo #
--echo # MDEV-33868 Assertion `trx->bulk_insert' failed in
--echo # innodb_prepare_commit_versioned
--echo #
CREATE TABLE t (id INT) ENGINE=InnoDB;
--replace_result $MYSQLTEST_VARDIR VARDIR
--disable_ps2_protocol
eval select 1 into outfile "$MYSQLTEST_VARDIR/tmp/t.outfile";
--enable_ps2_protocol
BEGIN;
--replace_result $MYSQLTEST_VARDIR VARDIR
eval LOAD DATA INFILE '$MYSQLTEST_VARDIR/tmp/t.outfile' INTO TABLE t;
COMMIT;
DROP TABLE t;
--remove_file $MYSQLTEST_VARDIR/tmp/t.outfile
--echo # End of 10.11 tests --echo # End of 10.11 tests
...@@ -5362,6 +5362,7 @@ void trx_t::bulk_rollback_low() ...@@ -5362,6 +5362,7 @@ void trx_t::bulk_rollback_low()
low_limit= t.second.get_first(); low_limit= t.second.get_first();
delete t.second.bulk_store; delete t.second.bulk_store;
t.second.bulk_store= nullptr; t.second.bulk_store= nullptr;
t.second.end_bulk_insert();
} }
} }
trx_savept_t bulk_save{low_limit}; trx_savept_t bulk_save{low_limit};
...@@ -5370,13 +5371,19 @@ void trx_t::bulk_rollback_low() ...@@ -5370,13 +5371,19 @@ void trx_t::bulk_rollback_low()
dberr_t trx_t::bulk_insert_apply_for_table(dict_table_t *table) dberr_t trx_t::bulk_insert_apply_for_table(dict_table_t *table)
{ {
auto t= check_bulk_buffer(table); if (UNIV_UNLIKELY(!bulk_insert))
if (!t || !t->is_bulk_insert())
return DB_SUCCESS; return DB_SUCCESS;
dberr_t err= t->write_bulk(table, this); ut_ad(!check_unique_secondary);
if (err != DB_SUCCESS) ut_ad(!check_foreigns);
bulk_rollback_low(); auto it= mod_tables.find(table);
return err; if (it != mod_tables.end() && it->second.bulk_store)
if (dberr_t err= it->second.write_bulk(table, this))
{
bulk_rollback_low();
return err;
}
it->second.end_bulk_insert();
return DB_SUCCESS;
} }
dberr_t trx_t::bulk_insert_apply_low() dberr_t trx_t::bulk_insert_apply_low()
......
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