Заглавная страница Избранные статьи Случайная статья Познавательные статьи Новые добавления Обратная связь FAQ Написать работу КАТЕГОРИИ: АрхеологияБиология Генетика География Информатика История Логика Маркетинг Математика Менеджмент Механика Педагогика Религия Социология Технологии Физика Философия Финансы Химия Экология ТОП 10 на сайте Приготовление дезинфицирующих растворов различной концентрацииТехника нижней прямой подачи мяча. Франко-прусская война (причины и последствия) Организация работы процедурного кабинета Смысловое и механическое запоминание, их место и роль в усвоении знаний Коммуникативные барьеры и пути их преодоления Обработка изделий медицинского назначения многократного применения Образцы текста публицистического стиля Четыре типа изменения баланса Задачи с ответами для Всероссийской олимпиады по праву Мы поможем в написании ваших работ! ЗНАЕТЕ ЛИ ВЫ?
Влияние общества на человека
Приготовление дезинфицирующих растворов различной концентрации Практические работы по географии для 6 класса Организация работы процедурного кабинета Изменения в неживой природе осенью Уборка процедурного кабинета Сольфеджио. Все правила по сольфеджио Балочные системы. Определение реакций опор и моментов защемления |
Реляционное исчисление кортежей и доменов.Содержание книги
Поиск на нашем сайте
Предположим, что мы работаем с базой данных, обладающей схемой Студенты (Номер зачётной книжки, Фамилия И. О., Номер группы, Адрес) и Группы (Номер группы, Число студентов, Староста) и хотим узнать фа милии, номера зачётных книжек и место жительства старост групп, число студентов которых превышает 20 человек. При использовании реляционной алгебры пришлось бы выполнить следующие вычисления: - выполнить соединение отношений Студенты и Группы по атрибутам Номер группы, Фамилия И.О. (требуется Переименование атрибута "Староста" в атрибут "Фамилия И.О. "); - ограничить полученное отношение по условию Число студентое>20] - спроецировать результат предыдущей операции на атрибуты: Номер зачётной книжки, Фамилия И. О., Адрес; - в полученном отношении переименовать атрибут Фамилия И.О. в атрибут Староста. Мы чётко сформулировали последовательность операций реляционной алгебры. Другими словами, алгебраическая формулировка запроса является процедурной, т.е. задающей правила выполнения запроса. Если же составить этот запрос с использованием реляционного исчисления, то полученную формулу можно прочитать так: "Выдать Номер зачётной книжки, Фамилию И.О., Адрес студентов, являющихся старостами групп, имеющих более 20 студентов". В этой формулировке содержится только характеристика результирующего отношения и не указывается путь её получения. Таким образом, логическая формулировка запроса является описательной (декларативной), поскольку она описывает лишь свойства желаемого результата. Как указывалось выше, на самом деле алгебраическая и логическая формы запроса взаимозаменяемы и существуют несложные правила преобразования одного формализма в другой. Реляционное исчисление является прикладной ветвью формального механизма исчисления предикатов первого порядка, базисными понятиями которого являются понятие переменной с определённой для неё областью допустимых значений и понятие правильно построенной формулы. При этом используются такие понятия, как переменные, предикаты и кванторы. В зависимости оттого, что является областью определения переменной, различают исчисление кортежей и исчисление доменов. В исчислении кортежей областями определения перемешщх являются отношения баз данных, т.е. допустимыми значениями каждой переменной является значение некоторого кортежа. В исчислении доменов областями определения переменных являются домены, определяющие допустимые значения атрибутов. Таким образом, каждая переменная является значением домена. Для определения кортежной переменной используется оператор RANGE. Например, для определения переменной "Студент", областью определения которой является отношение "Студенты", необходимо использовать запись: RANGE Студент IS Студенты. Как указывалось выше, переменная "Студент" представляет некоторый кортеж отношения "Студенты". При использовании кортежных переменных можно ссылаться на значения атрибута переменной (например, менных можно ссылаться на значения атрибута переменной (например, на атрибут "Фамилия И.О.), используя следующую конструкцию: Студент. Фамилия_К_0. Правильно построенные формулы ППФ (Well Formed Formula - WFF) служат для выражения условий, накладываемых на кортежные переменные. Основой правильно построенных формул являются простые сравнения (comparison), представляющие собой сравнение скалярных значений (значений атрибутов переменных или литерально заданных констант). Например, выполнение условия "в группе количество студентов превышает 20 человек" может быть записано следующим образом: Группа. Число^студентов > 20. Эта запись является простым сравнением и потому может считаться ППФ. Более сложные формулы могут быть построены путём использования скобок (заключённая в скобки ППФ является простым сравнением). Более сложные варианты ППФ строятся с помощью логических связок NOT, AND, OR и IF...THEN. Например, запись: Студент. Фамилия И. 0.= Группа. Староста AND (Группа. Число студентов > 20) позволяет выбрать из отношения фамилии старост групп, число студентов в которых превышает 20 человек. При построении ППФ могут использоваться кванторы существования EXISTS и всеобщности VORALL. Конструкции EXISTS var (form) и VORALL var (form) являются правильно постоенными формулами. Таким образом, ППФ обеспечивает средства формулировки условий выборки из отношений баз данных. Для определения набора и имён столбцов результирующего отношения используется компонент, получивший название " целевой список " (target Jist). Целевой список строится из целевых элементов, каждый из которых может иметь следующий вид: - var.attr, где var - имя свободной переменной соответствующей ППФ, attr - имя атрибута отношения, на котором определена переменная var; - var соответствует наличию подсписка var.attr 1, var.attr2,...var.attrn, где var.attrl, var.attr2,...var.attrn включает имена всех атрибутов отношения; - newname = var.attr; new_name - новое имя атрибута результирующего отношения. Последний целевой элемент используется в тех случаях, когда в ППФ необходимо иметь несколько свободных переменных с одинаковой областью определения. Выражением реляционного исчисления кортежей называется конструкция вида целевой список WHERE ППФ. Значением выражения является отношение, тело которого определяется ППФ, а набор атрибутов и их имена -Целевым списком. Вопрос 38 Пример использования реляционного исчисления для обработки данных. В рассмотренным выше примере выражение реляционного исчисления будет иметь следующий вид: RANGE Студент IS Студенты. RANGE Группа IS Группы. Номер зачётной книжки, Староста, Адрес = Студент. Номер зачётной книжки, Студент. Фамилия И. О., Студент. Адрес WHERE EXISTS Студент. (Студент. Фамилия И. О. = Группа.. Староста AND (Группа. Число студентов > 20)). В исчислении доменов областью определения переменных являются не отношения, а домены. Применительно к базе данных Студенты - Группы можно говорить, например, о доменных переменных Фамилия И. О. (значение - допустимые фамилии) или Номер зачётной книжки (значение -допустимые номера). Основным формальным отличием исчисления доменов от исчисления кортежей является наличие дополнительного набора предикатов, позволяющих выражать так называемое условия членства. Если R есть n-арное отношение с атрибутами aha2,...a„, то условие членства имеет вид: где v,y - это либо задаваемая константа, либо имя кортежной переменной. Условие членства принимает значение true в том случае, если в отношении R существует кортеж, содержащий заданные значения указанных атрибутов. Если Vy - константа, то на атрибут а$ задаётся условие, не зависящее от текущих значений доменных переменных. Если же Vy - имя доменной переменной, то условия членства могут принимать разные значения при разных значениях этой переменной; т - кардинальное число отношения. Во всех остальных отношениях формулы и выражения исчисления доменов строятся аналогично формулам и выражениям исчисления отношений. Пример 3.10. Составим выражение с использованием метода исчисления доменов, позволяющее выбрать фамилии и номера абитуриентов, получивших суммарный балл больше восьми. Отношение Абитуриенты имеет атрибуты Номер, Фамилия И. О., Балл. При этом последний атрибут может принимать значения Балл1=6, Балл2=7, БаллЗ=8, Балл4=9иБалл5=10. RANGE Абитуриент IS Абитуриенты. Номер, Фамилия И.О. = Абитуриент. Номер, Абитуриент. Фамилия И. О. WHERE EXISTS Абитуриент. (Абитуриент (Номер, Фамилия И. О., Балл) AND {Абитуриент. Балл > Абитуриент. БаллЗ)). Реляционное исчисление доменов является основой большинства языков запросов, основанных на использовании табличных форм.
Вопрос 39
|
||||
Последнее изменение этой страницы: 2016-04-07; просмотров: 786; Нарушение авторского права страницы; Мы поможем в написании вашей работы! infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 18.216.145.37 (0.007 с.) |