
- •Концепция баз данных
- •Понятие СУБД
- •Функции СУБД
- •3. Основные свойства баз данных.
- •Различие уровней представления данных на каждом этапе проектирования реляционной базы данных:
- •Примеры
- •Классификация моделей данных
- •Состав и назначение
- •Синтаксис
- •Пример
- •Синтаксис
- •Пример
- •Синтаксис
- •Пример
- •Синтаксис
- •Пример
- •Пример
- •Типы хранимых процедур
- •Создание, изменение и удаление хранимых процедур
- •Типы триггеров
- •Операторы создания, изменения
- •DML Trigger
- •DDL Trigger
- •Logon Trigger
- •DML Trigger
- •DDL Trigger
- •Logon Trigger
- •Поддержка ссылочной целостности с помощью триггеров
- •Агрегатные функции
- •Предложение GROUP BY
- •Вариант двумерного статистического запроса к БД
- •40. Общая характеристика и возможности системы.
- •43. Средства создания и коррекции структуры базы данных. Примеры.
- •45. Способы ускорения поиска данных: индексация и сортировка. Примеры.
- •40.13. Установка связей между таблицами
- •40.14. Импорт БД и установка связи с таблицами вне БД
- •40.15. Инструмент для установки связей
- •47. Средства создания приложений Примеры.
- •48. Средства задания ссылочной целостности.
- •Подуровни логического уровня модели данных
- •53. Генерация отчетов.
- •Использование Crystal Reports для создания отчетов
- •ACID-свойства транзакций
- •SET TRANSACTION ISOLATION LEVEL (SQL Server 2008 R2)
- •Оператор CREATE TABLE
- •Оператор ALTER TABLE
- •Оператор DROP TABLE
- •1. Сравнение
- •3. Принадлежность множеству
- •4. Соответствие шаблону
- •5. Значение NULL
- •Типы представлений:
- •Ограничения представлений:
- •Создание представлений
- •Использование T-SQL для изменения и удаления представлений
- •Объектно-ориентированная парадигма.
- •Многомерные базы данных (Multi-value Database)
- •Основные преимущества многомерных СУБД
- •Иерархическая модель данных
- •Сетевая модель данных
- •Реляционная структура данных
- •1. Уникальность: в произвольный заданный момент времени никакие два различных кортежа R не имеют одного и того же значения для Ai, Aj, ..., Ak.
- •Example.
- •Основные функции группы администратора БД
В каждой таблице или представлении может быть один триггер INSTEAD OF для каждого из действий, вызывающих срабатывание(UPDATE,DELETE или INSERT). Таблицаможет содержать несколько триггеров AFTER для каждого из вызывающих срабатывание действий.
Операторы создания, изменения
DML Trigger
[CREATE|ALTER] TRIGGER trigger_name ON { table | view }
{FOR | AFTER | INSTEAD OF }
{[ INSERT ] [ , ] [ UPDATE ] [ , ] [ DELETE ] }
AS { sql_statement }
DDL Trigger
[CREATE|ALTER] TRIGGER trigger_name ON { ALL SERVER | DATABASE }
{ FOR | AFTER } { event_type | event_group } [ ,...n ] AS { sql_statement }
Logon Trigger
[CREATE|ALTER] TRIGGER trigger_name ON ALL SERVER
{ FOR| AFTER } LOGON AS { sql_statement }
Операторыудаления
DML Trigger
DROP TRIGGER [schema_name.] trigger_name [ ,...n ] [ ; ]
DDL Trigger
DROP TRIGGER trigger_name [ ,...n ]
ON { DATABASE | ALL SERVER }
Logon Trigger
DROP TRIGGER trigger_name [ ,...n ]
ON ALL SERVER
Операторывключения, выключения
[ENABLE|DISABLE] TRIGGER { trigger_name [ ,...n ] | ALL } ON { object_name | DATABASE | ALL SERVER }
24. Т-SQL. Ссылочная целостность. Правила ссылочной целостности и поддержка ихс помощью триггеров. Примеры.
Ссылочнаяцелостность. База данных не должна содержать каких-либо несогласованных значений внешнего ключа. В этом определении термин "несогласованное значение внешнего ключа"обозначает значение внешнего ключа в некоторой ссылающейся переменной отношения, для которого не существует согласованного значения соответствующего потенциального ключа в соответствующей переменной отношения, указанной в ссылке.Иными словами, это ограничение можно сформулировать просто как следующее требование: "Если значение Вссылается на А, то А должно существовать".
Ссылочнаяцелостностьсохраняет определенные связи между таблицами при добавлении или удалении строк. В SQL Server ссылочная целостность основана на связи первичных и внешних ключей (либо внешних и уникальных ключей) и обеспечивается с помощью ограничений FOREIGN KEY и CHECK. Ссылочная целостность гарантирует согласованность значений ключей вовсех таблицах. Этот вид целостности требует отсутствия ссылок на несуществующие значения, а также обеспечивает согласованное изменение ссылок во всей базе данных при изменении значения ключа.
При обеспечении ссылочной целостности SQL Server не допускает следующих действий пользователей.
•Добавления или изменения строк в связанной таблице,если в первичной таблице нет соответствующей строки.
•Изменения значений в первичной таблице, которое приводит к появлению потерянных строк в связанной таблице.
•Удаления строк из первичной таблицы, если имеются соответствующие ей строки в связанных таблицах.
Ограничение FOREIGNKEY предотвращает возникновение ситуации несогласованности. Ограничение обеспечивает целостность ссылок следующим образом: оно запрещает изменение данных в таблице первичного ключа, если такие изменения сделаютнедопустимой ссылку в таблице внешнего ключа. Если при попытке удалить строку в таблице первичного ключа или изменить значение этого ключа окажется, что удаленному или измененному значению первичного ключа соответствует значение в ограничении FOREIGN KEY вдругой таблице, то действие выполнено не будет. Для успешного изменения или удаления строки с ограничением FOREIGN KEYнеобходимо сначала удалить данные внешнего ключа в соответствующей таблице либо изменить данные в таблице внешнего ключа, которые связывают внешний ключ с данными другого первичного ключа.
Поддержка ссылочной целостности с помощью триггеров
Триггеры DML часто используются для соблюдения бизнес-правил и целостности данных. В SQL Server декларативное ограничение ссылочной целостности обеспечивается инструкциями ALTER TABLE и CREATE TABLE. Однако декларативное ограничение ссылочной целостности не обеспечивает ссылочную целостность между базами данных. Ограничение ссылочной целостности подразумевает выполнение правил связи между первичными и внешними ключами таблиц. Для обеспечения ограничений ссылочной целостности используйте в инструкциях ALTER TABLE и CREATE TABLE ограничения PRIMARY KEY и FOREIGN KEY. Если ограничения распространяются на таблицу триггера,они проверяются после срабатывания триггера INSTEAD OF и до выполнения триггера AFTER. В случае нарушения ограничения выполняется откат действий триггера INSTEAD OF, и триггер AFTER не срабатывает.
Пример использования триггеров для поддержки ссылочной целостности– каскадное удаление или обновление данных
Пример каскадного удаления
CREATE TRIGGER delTrigger ON vuz_gorod FOR DELETE AS
BEGIN
DELETEvuz FROM deleted,vuz
WHERE vuz.cod=deleted.cod_vuza
END
Пример каскадного обновления
CREATE TRIGGER updTrigger ON vuz_gorod for update as
begin
update vuz
set vuz.cod = inserted.cod_vuza,vuz.uch_zavedenie = inserted.nazvanie_vuza from deleted,vuz,inserted
where ((deleted.cod_vuza = vuz.cod)
or (deleted.nazvanie_vuza = vuz.uch_zavedenie))
end

25. Т-SQL.Персональные,списковые и количественные запросы.Агрегатные функции. Особенности использования фразы group by.Реализация количественного запроса по одному или нескольким столбцам с использованием Т-SQL.Примеры.
Агрегатные функции
Агрегатные функции предназначены для того,чтобы вычислять некоторое значение для заданного множества строк. Таким множеством строк может быть группа строк,если агрегатная функция применяется к сгруппированной таблице, или вся таблица. Для всех агрегатныхфункций, кроме COUNT(*), фактический (т.е. требуемый семантикой) порядоквычислений следующий:на основании параметров агрегатной функции из заданного множества строк производится список значений. Затем по этому списку значений производится вычисление функции. Если список оказался пустым, то значение функции COUNT для него есть 0, а значение всех остальных функцийnull.
Вычисление функции COUNT(*) производится путем подсчета числа строк в заданном множестве. Все строки считаются различными, даже если они состоят из одного столбца со значением null во всех строках. Стандартом предусмотрены следующие агрегатныефункции:
Функция
COUNT(*)
COUNT(<имя поля>)
SUM(<имя поля>)
AVG(<имя поля>)
MIN(<имя поля>)
MAX(<имя поля>)
Описание
Возвращает количество строк источника записей.
Возвращает количество значений в указанном столбце.
Возвращает сумму значений в указанном столбце.
Возвращает среднее значение в указанном столбце.
Возвращает минимальное значение в указанном столбце.
Возвращает максимальное значение в указанном столбце.
Все эти функции возвращают единственное значение. При этом функцииCOUNT, MINиMAXприменимы к любым типам данных, в то время какSUM иAVGиспользуются только для числовых полей. Разница между функциейCOUNT(*)иCOUNT(<имя поля>)состоит в том,чтовторая при подсчете не учитывает NULL-значения.
Предложение GROUP BY
Предложение GROUP BY позволяет вам определять подмножество значений в особом поле в терминах
другого пол, и применятьфункцию агрегатак подмножеству. Это дает вам возможность объединять поли агрегатные функции в едином предложении SELECT. Например,предположим что выхотите найти наибольшуюсумму приобретений полученнуюкаждым продавцом. Выможете сделать раздельный запрос для каждого из них, выбрав MAX (amt) из таблицыПорядков для каждогозначения пол snum. GROUP BY, однако,позволитВам поместить их все водну команду:
=============== SQL Execution Log ==============
| |
| |
| SELECT snum, MAX (amt) |
| |
| FROM Orders |
| |
| GROUP BY snum; |
| |
| =============================================== |
| snum |
|
| |
|
| ------ |
-------- |
| |
|
| |
1001 |
767.19 |
| |
| |
1002 |
1713.23 |
| |
| |
1003 |
75.75 |
| |
| |
1014 |
1309.95 |
| |
================================================
GROUP BY применяет агрегатные функции независимо от серий групп которые определяются с помощью значения поля в целом. В этом случае, каждая группа состоит из всех строк с тем же самым значениемпол snum, и MAX функция применяется отдельно для каждой такой группы. Это значение пол, к которому применяется GROUP BY, имеет, поопределению, только одно значение на группу вывода, также как это делает агрегатная функция. Результатом является совместимость которая позволяет агрегатам и полям