Специальные реляционные операции
Операция ограничения по условию требует наличия двух операндов: отношения, которое подвергается ограничению, и условия ограничения. Условие ограничения имеет вид: , где – операция сравнения (<, >, =, £, ³), а и – атрибуты ограничиваемого отношения или константы. Результатом этой операции является отношение, в которое включаются только такие кортежи из исходного, в которых значения атрибутов удовлетворяют условию ограничения.
Операция проекции требует наличия двух операндов: исходного проецируемого отношения и списка имён атрибутов, входящих в заголовок исходного отношения. Проекция на заданный набор атрибутов – отношение, в котором из исходных кортежей выбираются те атрибуты, которые входят в проектируемый список.
Т.к. получающиеся отношения не удовлетворяют фундаментальным свойствам отношений, то кортежи-дубликаты удаляются.
Соединение двух отношений по условию требует наличия трёх операндов: два отношения, соединяемых между собой, и условия выполнения соединения.
Результатом соединения будет отношение, в котором кортежи являются сцеплением кортежей первого и второго отношений именно таких, которые удовлетворяют условию.
Важным частным случаем этой операции является эквисоединение, когда в качестве условия выступает равенство . В результате этой операции:
Здесь два столбца дублируют друг друга. Тогда столбец-дублёр вычёркивается. Смысл эквисоединения состоит в восстановлении какой-то сложной сущности.
Операция деления отношений была введена для обеспечения свойства замкнутости. В делении участвуют два операнда: бинарное отношение и унарное отношение. Результатом этой операции является отношение из одно-атрибутных кортежей, включающих значение первого атрибута кортежей первого операнда таких, что значения второго атрибута совпадают со множеством значений второго операнда.
операция присваивания – операция, которая сохраняет результат вычисления реляционного выражения в виде нового отношения. Т.е. можно увеличивать количество отношений в БД.
Дата добавления: 2014-12-20; просмотров: 670;