WikiDer > Чейз (алгоритм)

Chase (algorithm)

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

Эта погоня берет свое начало в двух основополагающих статьях 1979 г. Альфред В. Ахо, Катриэль Бери, и Джеффри Д. Уллман[1] а другой Дэвид Майер, Альберто О. Мендельзон, и Иегошуа Сагив.[2]

В простейшем случае погоня используется для проверки того, проекция из схема отношений сдерживается некоторыми функциональные зависимости на данное разложение можно восстановлен путем воссоединения с прогнозами. Позволять т быть кортежем в где р это связь и F представляет собой набор функциональных зависимостей (ФЗ). Если кортежи в р представлены как т1, ..., тk, объединение проекций каждого тя должен согласиться с т на где я = 1, 2, ..., k. Если тя не на , значение неизвестно.

Погоня может быть выполнена путем рисования таблицы (это тот же формализм, что и в запрос таблицы). Предположим р имеет атрибуты А, Б, ... и компоненты т находятся а, б, .... За тя используйте ту же букву, что и т в компонентах, входящих в Sя но подпишите букву я если компонент не находится в Sя. Потом, тя согласен с т если он находится в Sя и будет иметь уникальное значение в противном случае.

Процесс погони сливаться. Существуют реализации алгоритма погони,[3] некоторые из них также имеют открытый исходный код.[4]

пример

Позволять р(А, B, C, D) быть схемой отношений, которая, как известно, подчиняется набору функциональных зависимостей F = {АB, BC, CD → A}. Предположим р раскладывается на три схемы отношений S1 = {А, D}, S2 = {А, C} и S3 = {B, C, D}. Определить, является ли это разложение без потерь, можно, выполнив чейз, как показано ниже.

Исходная таблица для этого разложения:

АBCD
аб1c1d
аб2cd2
а3бcd

Первая строка представляет S1. Компоненты для атрибутов А и D без индексов, а для атрибутов B и C подписаны с я = 1. Вторая и третья строки заполняются аналогично S2 и S3 соответственно.

Цель этого теста - использовать данный F чтобы доказать, что т = (а, б, c, d) действительно в р. Для этого за таблицей можно следить, применяя ФД в F приравнять символы в таблице. Итоговая таблица со строкой такая же, как т означает, что любой кортеж т в соединении проекций фактически является кортежем р.
Чтобы выполнить тест чейза, сначала разложите все FD в F так что каждый FD имеет единственный атрибут справа от «стрелки». (В этом примере F остается без изменений, потому что все его FD уже имеют один атрибут с правой стороны: F = {АB, BC, компакт дискА}.)

При приравнивании двух символов, если один из них не имеет индекса, сделайте другой таким же, чтобы в итоговой таблице могла быть строка, точно такая же, как т = (а, б, c, d). Если у обоих есть свой индекс, замените одно на другое. Однако, чтобы избежать путаницы, все вхождения следует изменить.
Сначала примените АB к таблице. первая строка (а, б1, c1, d) где а без подписи и б1 имеет индекс 1. Сравнивая первую строку со второй, измените б2 к б1. Поскольку в третьей строке а3, б в третьем ряду остается прежним. Итоговая таблица:

АBCD
аб1c1d
аб1cd2
а3бcd

Тогда рассмотрим BC. И первый, и второй ряды имеют б1 и обратите внимание, что во второй строке есть неподписанный c. Таким образом, первая строка изменится на (а, б1, c, d). Тогда итоговая таблица выглядит так:

АBCD
аб1cd
аб1cd2
а3бcd

Теперь рассмотрим компакт дискА. В первой строке есть неподписанный c и неподписанный d, что такое же, как в третьей строке. Это означает, что значение A для первой и третьей строк также должно быть одинаковым. Следовательно, изменим а3 в третьем ряду а. Итоговая таблица:

АBCD
аб1cd
аб1cd2
абcd

На этом этапе обратите внимание, что третья строка (а, б, c, d), который совпадает с т. Таким образом, это финальная таблица для теста чейза с заданными р и F. Следовательно, всякий раз, когда р проецируется на S1, S2 и S3 и вернулся, результат в р. В частности, полученный кортеж совпадает с кортежем р который проецируется на {B, C, D}.

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

  1. ^ Альфред В. Ахо, Катриэль Бери, и Джеффри Д. Уллман: "Теория объединений в реляционных базах данных", ACM Trans. Датаб. Syst. 4 (3): 297-314, 1979.
  2. ^ Дэвид Майер, Альберто О. Мендельзон, и Иегошуа Сагив: "Тестирование последствий зависимостей данных". ACM Trans. Датаб. Syst. 4 (4): 455-469, 1979.
  3. ^ Майкл Бенедикт, Георгий Константинидис, Джиансальваторе Мекка, Борис Мотик, Паоло Папотти, Донателло Санторо, Эфтимия Цамура: Сравнительный анализ погони. В Proc. PODS, 2017.
  4. ^ "Llunatic Mapping and Cleaning Chase Engine".

дальнейшее чтение

  • Серхио Греко; Франческа Спеццано; Кристиан Молинаро (2012). Неполные данные и зависимости данных в реляционных базах данных. Издательство Morgan & Claypool. ISBN 978-1-60845-926-1.