commit
просто ангажира всяка текуща транзакция в ход към вашата база данни.
Какво всъщност питате дали премахването на индекси и след това копирането в рамките на една и съща транзакция ще осигури същото ускоряване като първо премахване на индекси в една транзакция и след това копиране на данни в нова транзакция.
Директният цитат от docs казва, че:
Удебелената част индиректно казва, че трябва да се ангажирате след премахване на индексите, тъй като премахването на индекси без ангажиране (завършване на транзакцията) не трябва да има никакво въздействие върху други потребители на базата данни.
Така че решението трябва да е нещо подобно:
изтрийте вашите индекси, ангажирайте, копирайте данните, създайте нови индекси и ангажирайте отново.
Обърнете внимание, че докато разделяте транзакцията си на две, губите атомарност. т.е. възможно е вашите индекси да бъдат премахнати, но не се копират никакви данни (ако захранването или мрежата например се загубят по време на транзакцията за копиране) и индексите никога няма да бъдат създадени отново.