Проблема Хэллоуина - Halloween Problem

В вычислениях Проблема Хэллоуина относится к явлению в базы данных в котором Обновить операция вызывает изменение физического расположения строки, потенциально позволяя посещать строку более одного раза во время операции. Это может даже вызвать бесконечный цикл в некоторых случаях, когда обновления постоянно помещают обновленную запись перед сканированием, выполняющим операцию обновления.

Возможность возникновения этой ошибки базы данных была впервые обнаружена Дон Чемберлин, Пэт Селинджер, и Мортон Астрахан в 1976 г. Хэллоуин день, работая над запросом, который должен был дать десятипроцентную прибавку каждому сотруднику, заработавшему менее 25000 долларов. Этот запрос будет выполнен успешно, без ошибок, но по завершении все сотрудники в базе данных заработали не менее 25 000 долларов, потому что он продолжал повышать их, пока они не достигли этого уровня. Ожидалось, что запрос будет повторять итерацию по каждой записи о сотруднике с зарплатой менее 25000 долларов ровно один раз. Фактически, поскольку даже обновленные записи были видны механизму выполнения запроса и, таким образом, продолжали соответствовать критериям запроса, записи о заработной плате совпадали несколько раз и каждый раз получали повышение на 10%, пока все они не превысили 25 000 долларов.

Название не описывает природу проблемы, а скорее дано в честь дня, когда она была обнаружена. Как рассказывает Дон Чемберлин:

Пэт и Мортон обнаружили эту проблему на Хэллоуин ... Я помню, они вошли в мой офис и сказали: «Чемберлин, посмотри на это. Мы должны убедиться, что когда оптимизатор составляет план обработки обновления, он не использует индекс, основанный на обновляемом поле. Как мы собираемся это сделать? »Это случилось в пятницу, и мы сказали:« Послушайте, сегодня днем ​​мы не сможем решить эту проблему. Давай просто дадим ему имя. Мы назовем это проблемой Хэллоуина и поработаем над этим на следующей неделе ''. И, оказывается, с тех пор так и называется.

Рекомендации