Не, механизмите за автоматично увеличение трябва работи извън обхвата на транзакциите, защото друг потребител може да вмъква в същата таблица, преди да завършите транзакцията си. Транзакцията на другия потребител трябва да може да разпредели следващата стойност, преди да разбере дали вашата транзакция използва стойността, която току-що сте разпределили.
Относно вашия коментар:Ако мога да го кажа по-ясно, всяка промяна в обхвата на транзакция може да бъде отменена. Броячът за автоматично увеличение не се връща назад, така че не се подчинява на атомарност на транзакции. Нито се подчинява наизолацията защото друга транзакция получава следващата стойност, въпреки че транзакцията ви все още не е ангажирана.
Начинът, по който работи автоматичното увеличение, означава, че понякога, ако вмъкнете някои редове и след това върнете транзакцията си назад, стойностите, които сте разпределили с автоматично увеличение, се губят завинаги!
Но това е наред. Стойностите на първичния ключ трябва да са уникални, но не е необходимо да са последователни. С други думи, те не са номера на редове и не бива да ги използвате по този начин. Така че никога не трябва да намалявате стойностите, създадени чрез автоматично увеличение.