Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему Базы Данных

Содержание

Домашнее заданиеДля каждого уникального товара вывести количество купленных товаров в заказах. В выводе должно быть (DESCRIPTION, SUM_QTY)
Базы ДанныхЛекция 4 Домашнее заданиеДля каждого уникального товара вывести количество купленных товаров в заказах. В Домашнее заданиеselect DESCRIPTION, sum(SUM_QTY) as SUM_QTYfrom (	select MFR, PRODUCT, sum(SUM_QTY) as SUM_QTY	from Домашнее заданиеSQLITE:SELECT DISTINCT DESCRIPTION, SUM(QTY) AS sum_qtyFROM ORDERS, PRODUCTSWHERE (trim(PRODUCT) = trim(PRODUCT_ID))AND Домашнее заданиеORACLE:SELECT DISTINCT DESCRIPTION, SUM(QTY) AS sum_qtyFROM ORDERS, PRODUCTSWHERE PRODUCT = PRODUCT_IDAND Домашнее заданиеДля каждого сотрудника определить, что больше: отношение квоты сотрудника к квоте Домашнее заданиеselect NAME as Name, COALESCE(CITY, 'N/A') as OFFICE,	case 		when (TARGET is Домашнее заданиеНеобходимо рассмотреть только те заказы сотрудника, сумма которых больше средней суммы Домашнее задание 3 ORACLESELECT NAME, COUNT(*) AS cnt_of_ordersFROM ORDERS O	INNER JOIN SALESREPS Домашнее задание 3 SQLITESELECT NAME, COUNT(*) AS cnt_of_ordersFROM ORDERS O	INNER JOIN SALESREPS Домашнее задание 4Вывести только те товары, для которых количество на складе меньше Домашнее задание 4 sqlite	select DESCRIPTION	from PRODUCTS join (		select MFR, PRODUCT, sum(QTY) as Домашнее задание 4 sqliteSELECT DESCRIPTIONFROM PRODUCTS WHERE QTY_ON_HAND = 0.8 * (SELECT Домашнее задание 4 oracleSELECT DESCRIPTIONFROM PRODUCTS WHERE QTY_ON_HAND = 0.8 * (SELECT Домашнее задание 5Для каждого дня, когда был совершен заказ или принят сотрудник, Домашнее задание 5 oracle	select date, abs(cnt) as abs_diff	from (		select HIRE_DATE as date, Домашнее задание 6* Учитывая условия задачи 5 найти даты с минимальными и Домашнее задание 6	select date, abs(sum(val_hire)-sum(val_order)) as abs_diff	from (		select HIRE_DATE as date, count(*) Домашнее задание 6having abs_diff in (		/* Поиск минимума среди абсолютной разности */		select Домашнее задание 6		union		/* Поиск максимума среди абсолютной разности */		select max(abs_diff) as val		from Домашнее задание 6WITH DIFF_CALCAS (	select date, abs(cnt) as abs_diff	from (		select HIRE_DATE as Домашнее задание 6SELECT date, abs_diffFROM hw3_t5_tmp WHERE abs_diff = (SELECT max(abs_diff) FROM Домашнее задание 7Вывести только те товары, по которым было совершенно менее, чем Домашнее задание 7SELECT DESCRIPTIONFROM PRODUCTSWHERE NOT EXISTS (SELECT 1FROM ORDERS WHERE MFR_ID Обработка транзакцийЧасто база данных должна обрабатывать события, которые приводят более чем к Обработка транзакцийРассмотрим событие – прием нового заказа от клиента Добавление нового заказа Обработка транзакцийДля избегания нарушений целостности базы данных, четыре указанных изменения следует выполнить как единое целое. Обработка транзакцийДля избегания нарушений целостности базы данных, четыре указанных изменения следует выполнить Обработка транзакцийИзменения базы данных, которые были вызваны одним событием, необходимо вносить по Обработка транзакцийТранзакция – это несколько последовательных инструкций SQL, которые вместе образуют логическую Обработка транзакцийТранзакция – это несколько последовательных инструкций SQL, которые вместе образуют логическую Обработка транзакцийГруппировка инструкций в единую транзакцию указывает СУБД, что вся их последовательность Обработка транзакцийAtomic (Атомарность). “Все, или ничего”. Выполняются успешно либо все операции транзакции, Обработка транзакцийConsistent (Целостность). Транзакций должна переводить БД из одного согласованного состояния в Обработка транзакцийIsolated (Изолированность). Каждая транзакция должна выполняться сама по себе, без взаимодействия Обработка транзакцийDurable (Постоянство). По завершении транзакции все внесенные ею изменения должны быть Обработка транзакцийПример транзакций:Прием заказа. Программа ввода заказа должна:Выполнить запрос к Products и Обработка транзакцийПример транзакций:Прием заказа. Программа ввода заказа должна:(d) Обновить таблицу SALESREPS, добавив Обработка транзакцийПример транзакций:Отмена заказа. Удалить заказ из таблицы ORDERS.Обновить таблицу PRODUCTS, откорректировав Обработка транзакцийПример транзакций:Перевод клиента. Обновить таблицу CUSTOMERS;Обновить таблицу ORDERS, изменив имя служащего, Обработка транзакций Инструкции, входящие в транзакцию, выполняются атомарно, как единое неделимое целое. Обработка транзакцийSELECTSELECTSELECTSELECTUPDATEUPDATEUPDATEUPDATEUPDATEUPDATEАппаратный сбойSAVEPOINTDELETEDELETEDELETEПрограммная ошибкаСУБДотменяет всеизмененияСУБДотменяет всеизмененияПрограммная ошибкаСУБДотменяет всеизмененияINSERTСостояние БД после транзакции Модель транзакции ANSI/ISO SQL В стандарте ANSI/ISO определена модель транзацкций SQL, а Модель транзакции ANSI/ISO SQL - START TRANSACTION. Устанавливает свойства новой транзакции и запускает транзакцию Модель транзакции ANSI/ISO SQL START TRANSACTION. SET TRANSACTION. Устанавливает свойства очередной выполняемой Модель транзакции ANSI/ISO SQL START TRANSACTION. SET TRANSACTION. SET CONSTRAINTS. Устанавливает режим Модель транзакции ANSI/ISO SQL START TRANSACTION. SET TRANSACTION. SET CONSTRAINTS. SAVEPOINT. Создает Модель транзакции ANSI/ISO SQL START TRANSACTION. SET TRANSACTION. SET CONSTRAINTS. SAVEPOINT. RELEASE Модель транзакции ANSI/ISO SQL COMMIT. Завершает успешную транзакцию и сохраняет все внесенные Модель транзакции ANSI/ISO SQL ROLLBACK. При использовании без точки сохранения прекращает неудачную Инструкции SET TRANSACTION и START TRANSACTION Инструкции SAVEPOINT и RELEASE SAVEPOINTSAVEPOINT имя_точки_сохранения;Преимущество – возможность отката части транзакции в Инструкции SAVEPOINT и RELEASE SAVEPOINTSAVEPOINT имя_точки_сохранения;Недостаток – потенциальное использование большого кол-ва ресурсов. RELEASE SAVEPOINT имя_точки_сохранения; Инструкции COMMIT и ROLLBACKCOMMIT [WORK] [AND [NO] CHAIN]ROLLBACK [WORK] [AND [NO] CHAIN] Пример COMMITИзменить объем заказа 113051 с 4 до 10 единиц, что повышает Пример COMMITUPDATE OFFICES SET SALES = SALES – 1458.00 + 3550.00WHERE OFFICE Пример ROLLBACKUPDATE ORDERS SET QTY = 10, AMOUNT = 3550.00WHERE ORDER_NUM = Пример ROLLBACKUPDATE OFFICES SET SALES = SALES – 1458.00 + 3550.00WHERE OFFICE Транзакции и работа в многопользовательском режимеЕсли с БД работают одновременно двое или DIRTY WRITE P0Транзакция T1 модифицирует строку. Другая транзакция T2 также модифицирует эту DIRTY READ P1SELECT QTY_ON_HAND FROM PRODUCTS Ответ:139UPDATE PRODUCTSSET QTY_ON_HAND = 39SELECT QTY_ON_HAND P2 NONREPEATABLE READSELECT QTY_ON_HAND FROM PRODUCTS Ответ:139SELECT QTY_ON_HAND FROM PRODUCTS Ответ:139SELECT QTY_ON_HAND FROM PRODUCTS Ответ:39 P3 PHANTOMSELECT * FROM ORDERS112962,31500113012,3745INSERT INTO VALUES(118102, .., 5.000)COMMITSELECT * FROM ORDERS112962,31500113012,3745118102,5000 P4 LOST UPDATESELECT QTY_ON_HAND FROM PRODUCTS Ответ:139UPDATE PRODUCTSSET QTY_ON_HAND = 39SELECT QTY_ON_HAND Блокировка при параллельном выполнении 2 транзакций Уровни блокировкиНа уровне БДНа уровне таблицыНа уровне страницНа уровне строк Виды блокировокБлокировка с обеспечением совместного доступа, или блокировка без монополизации (shared lock). Виды блокировокМонопольная, или исключающая блокировка (exclusive lock). Когда транзакция обновляет информацию в Правила применения блокировок Виды блокировок Виды блокировок Усовершенствованные методы блокировокЯвная блокировка.Уровни изоляции.Параметры блокировки. Уровни изоляции Архитектура управления версиями РезюмеВ РСУБД транзакция представляет собой логическую единицу работы. Транзакция состоит из последовательности РезюмеИнструкция RELEASE SAVEPOINT удаляет точку сохранения и освобождает захваченные ею ресурсы.Инструкция COMMIT РезюмеТранзакции играют ключевую роль при параллельном доступе к данным в многопользовательской базе РезюмеМногие СУБД для обработки параллельных транзакций применяют методику блокировки. Изменение параметров блокировок Создание базы данных- Инструкции SELECT, INSERT, UPDATE, COMMIT, ROLLBACK, DELETE предназначены для Создание базы данных- Для изменения структуры базы данных предназначен другой набор инструкций DDLОпределить структуру новой таблицы и создать ее;Удалить таблицу, которая больше не нужна;Изменить DDLЯдро языка определения данных образуют три команды:CREATE (создать), позволяющая определить и создать Создание базы данныхCREATE DATABASEDROP DATABASE Определение таблицВ реляционной базе данных наиболее важным элементом ее структуры является таблицаТаблица Создание таблицы (CREATE TABLE) Определения столбцов- Имя столбца. Используется для обращения к столбцу в инструкциях SQL. Определения столбцовТип данных. Указывает тип столбца. Иногда указывается доп. информация, такая как Определения столбцовОбязательность данных. Определяет, допускаются ли в данном столбце значения NULL.Значения по Пример ORACLECREATE TABLE OFFICES(	OFFICE NUMERIC(10, 0) NOT NULL,	CITY VARCHAR2(15) 	NOT NULL,	REGION VARCHAR2(10)	NOT Пример ORACLECREATE TABLE ORDERS (	ORDER_NUM NUMERIC(10, 0) NOT NULL,	ORDER_DATE DATE NOT NULL,	CUST Пример ORACLECREATE TABLE ORDERS (	ORDER_NUM NUMERIC(10, 0) NOT NULL,	ORDER_DATE DATE NOT NULL,	CUST Значения по умолчанию и отсутствующие значенияCREATE TABLE OFFICES (	OFFICE NUMERIC(10,0) NOT NULL,	CITY Ограничения Определение первичного ключаВ предложении PRIMARY KEY задается столбец или столбцы, которые образуют Определение внешнего ключа Определение внешнего ключаСтоблец или столбцы создаваемой таблицы, которые создают внешний ключ.Таблица, связь Определение внешнего ключаНеобязательное имя для этого отношения; оно не используется в инструкциях Определение внешнего ключаНеобязательное правило удаления для данного отношения (CASCADE, SET NULL, SET Определение внешнего ключаНеобязательное условие на значения, которое ограничивает данные в таблице так, Пример с PRIMARY и FOREIGN KEYCREATE TABLE ORDERS(	ORDER_NUM INTEGER NOT NULL,	ORDER_DATE DATE Пример с PRIMARY и FOREIGN KEYPRIMARY KEY (ORDER_NUM), CONSTRAINT PLACEDBY FOREIGN KEY Условия уникальностиСтандарт SQL определяет, что условия уникальности также задаются в инструкции CREATE Пример с UNIQUECREATE TABLE OFFICES(	OFFICE INTEGER NOT NULL,  CITY VARCHAR(15) NOT Ограничения на значения столбцов Ограничение на значения столбцов связано с инструкцией CHECK. Пример с CHECKCREATE TABLE OFFICES   (OFFICE INTEGER NOT NULL, Удаление таблицы Изменение определения таблицыДобавить в каждую строку таблицы CUSTOMERS имя и номер телефона Изменение определения таблицыСделать столбец REGION таблицы OFFICES внешним ключом для вновь созданной Изменение определения таблицы Изменение определения таблицыДобавить в таблицу определение столбца;Удалить столбец из таблицы;Изменить значение по Добавление в таблицу столбцовALTER TABLE CUSTOMERSADD CONTACT_NAME VARCHAR(30);ALTER TABLE CUSTOMERSADD COLUMN CONTACT_PHONE Удаление столбцовALTER TABLE CUSTOMERSDROP CONTACT_NAME; Изменения первичных и внешних ключейALTER TABLE OFFICESADD CONSTRAINT INREGION FOREIGN KEY (REGION)REFERENCES Основные понятия ER-диаграммОпределение 1. Сущность - это класс однотипных объектов, информация о которых должна быть учтена в модели. Основные понятия ER-диаграммhttp://citforum.ru/database/dblearn/dblearn08.shtml Статья по разделу Основные понятия ER-диаграммОпределение 2. Экземпляр сущности - это конкретный представитель данной сущности.Например, представителем сущности Основные понятия ER-диаграммОпределение 3. Атрибут сущности - это именованная характеристика, являющаяся некоторым свойством сущности.Наименование Основные понятия ER-диаграмм Основные понятия ER-диаграммОпределение 4. Ключ сущности - это неизбыточный набор атрибутов, значения которых в совокупности являются уникальными для Основные понятия ER-диаграмм Основные понятия ER-диаграммОпределение 5. Связь - это некоторая ассоциация между двумя сущностями. Одна сущность может быть Основные понятия ER-диаграмм Основные понятия ER-диаграммКаждая связь имеет два конца и одно или два наименования. Основные понятия ER-диаграмм Основные понятия ER-диаграммСвязь типа один-к-одному означает, что один экземпляр первой сущности (левой) связан с Основные понятия ER-диаграммСвязь типа один-ко-многим означает, что один экземпляр первой сущности (левой) связан с Основные понятия ER-диаграммСвязь типа много-ко-многим означает, что каждый экземпляр первой сущности может быть связан Основные понятия ER-диаграммКаждая связь может иметь одну из двух модальностей связи: Основные понятия ER-диаграммМодальность Основные понятия ER-диаграммПри разработке ER-моделей мы должны получить следующую информацию о предметной Основные понятия ER-диаграммПредположим, что перед нами стоит задача разработать информационную систему по Основные понятия ER-диаграммНапример, выяснилось, что проектируемая система должна выполнять следующие действия:Хранить информацию Основные понятия ER-диаграммВыделим все существительные в этих предложениях - это будут потенциальные Основные понятия ER-диаграмм Основные понятия ER-диаграммФормируем атрибуты сущности:Каждый покупатель является юридическим лицом и имеет наименование, Основные понятия ER-диаграмм Основные понятия ER-диаграммРазработанный выше пример ER-диаграммы является примером концептуальной диаграммы. Это означает, что Основные понятия ER-диаграмм Нормальные формыСтатья - https://habrahabr.ru/post/254773/ Нормальные формыИспользуемые термины Атрибут — свойство некоторой сущности. Часто называется полем таблицы. Нормальные формыПроекция — отношение, полученное из заданного путём удаления и (или) перестановки некоторых Нормальные формыЦель нормализации: исключить избыточное дублирование данных, которое является причиной аномалий, возникших Первая нормальная формаОтношение находится в 1НФ, если все его атрибуты являются простыми, Первая нормальная форма Вторая нормальная формаОтношение находится во 2НФ, если оно находится в 1НФ и Вторая нормальная формаТаблица находится в первой нормальной форме, но не во второй. Вторая нормальная форма Третья нормальная формаОтношение находится в 3НФ, когда находится во 2НФ и каждый Третья нормальная форма Третья нормальная формаТаблица находится во 2НФ, но не в 3НФ. В отношении Третья нормальная форма Нормальная форма Бойса-Кодда (НФБК) (частная форма третьей нормальной формы)Определение 3НФ не совсем BCNFвозможны следующие составные первичные ключи: {Номер стоянки, Время начала}, {Номер стоянки, Время BCNFОтношение находится в 3НФ. Требования второй нормальной формы выполняются, так как все BCNF Домашнее задание1. Описать вашу БД для курсовой, как ее можно применять, какие Домашнее задание6. Написать DML скрипты для INSERT, DELETE, UPDATE.7. Привести пример транзакции.
Слайды презентации

Слайд 2 Домашнее задание
Для каждого уникального товара вывести количество купленных

Домашнее заданиеДля каждого уникального товара вывести количество купленных товаров в заказах.

товаров в заказах. В выводе должно быть (DESCRIPTION, SUM_QTY)


Слайд 3 Домашнее задание
select DESCRIPTION, sum(SUM_QTY) as SUM_QTY
from (
select MFR,

Домашнее заданиеselect DESCRIPTION, sum(SUM_QTY) as SUM_QTYfrom (	select MFR, PRODUCT, sum(SUM_QTY) as

PRODUCT, sum(SUM_QTY) as SUM_QTY
from (
/* Все уникальные товары из

таблицы PRODUCTS */
select MFR_ID as MFR, trim(PRODUCT_ID) as PRODUCT, 0 as SUM_QTY
from PRODUCTS
union
/* Все уникальные товары с суммой по количеству в заказах по каждому товару из таблицы ORDERS */
select MFR, trim(PRODUCT) as PRODUCT, sum(QTY) as SUM_QTY
from ORDERS
group by MFR, PRODUCT
)
group by MFR, PRODUCT
) join PRODUCTS on (trim(PRODUCT_ID) = PRODUCT and MFR = MFR_ID)
group by MFR, PRODUCT;

Слайд 4 Домашнее задание
SQLITE:
SELECT DISTINCT DESCRIPTION, SUM(QTY) AS sum_qty
FROM ORDERS,

Домашнее заданиеSQLITE:SELECT DISTINCT DESCRIPTION, SUM(QTY) AS sum_qtyFROM ORDERS, PRODUCTSWHERE (trim(PRODUCT) =

PRODUCTS
WHERE (trim(PRODUCT) = trim(PRODUCT_ID))
AND (trim(MFR) = trim(MFR_ID))
GROUP BY PRODUCT_ID,

MFR_ID;

Слайд 5 Домашнее задание
ORACLE:
SELECT DISTINCT DESCRIPTION, SUM(QTY) AS sum_qty
FROM ORDERS,

Домашнее заданиеORACLE:SELECT DISTINCT DESCRIPTION, SUM(QTY) AS sum_qtyFROM ORDERS, PRODUCTSWHERE PRODUCT =

PRODUCTS
WHERE PRODUCT = PRODUCT_ID
AND trim(MFR) = MFR_ID
GROUP BY PRODUCT_ID,

MFR_ID, DESCRIPTION;

Слайд 6 Домашнее задание
Для каждого сотрудника определить, что больше: отношение

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

квоты сотрудника к квоте офиса или продаж сотрудника к

продажам офиса и вывести наибольшее из них. Если определить нельзя, то вывести ноль. Также вывести город сотрудника; Если офис для сотрудника не определен, то вывести ‘N/A’; В выводе должно быть (Name, OFFICE, res)

Слайд 7 Домашнее задание
select NAME as Name, COALESCE(CITY, 'N/A') as

Домашнее заданиеselect NAME as Name, COALESCE(CITY, 'N/A') as OFFICE,	case 		when (TARGET

OFFICE,
case
when (TARGET is null or TARGET = 0

or OFFICES.SALES = 0)
then 0
when (QUOTA*1.0/TARGET > SALESREPS.SALES*1.0/OFFICES.SALES)
then QUOTA*1.0/TARGET
when (QUOTA*1.0/TARGET < SALESREPS.SALES*1.0/OFFICES.SALES)
then SALESREPS.SALES*1.0/OFFICES.SALES
else 0
end as res
from SALESREPS left join OFFICES on (REP_OFFICE = OFFICE);

Слайд 8 Домашнее задание
Необходимо рассмотреть только те заказы сотрудника, сумма

Домашнее заданиеНеобходимо рассмотреть только те заказы сотрудника, сумма которых больше средней

которых больше средней суммы заказов данного сотрудника, которые были

совершены в 2007 году. Из полученных заказов сформировать итоговой вывод, который для каждого сотрудника указывает количество таких заказов. В выводе должно быть (NAME, cnt_of_orders)

Слайд 9 Домашнее задание 3 ORACLE
SELECT NAME, COUNT(*) AS cnt_of_orders
FROM

Домашнее задание 3 ORACLESELECT NAME, COUNT(*) AS cnt_of_ordersFROM ORDERS O	INNER JOIN

ORDERS O
INNER JOIN SALESREPS
ON O.REP = SALESREPS.EMPL_NUM
WHERE

AMOUNT > (SELECT avg(AMOUNT) FROM ORDERS WHERE O.REP = ORDERS.REP
AND (EXTRACT(YEAR FROM ORDER_DATE) = 2007))
GROUP BY REP, NAME;

Слайд 10 Домашнее задание 3 SQLITE
SELECT NAME, COUNT(*) AS cnt_of_orders
FROM

Домашнее задание 3 SQLITESELECT NAME, COUNT(*) AS cnt_of_ordersFROM ORDERS O	INNER JOIN

ORDERS O
INNER JOIN SALESREPS
ON O.REP = SALESREPS.EMPL_NUM
WHERE
AMOUNT

> (SELECT avg(AMOUNT) FROM ORDERS
WHERE O.REP = ORDERS.REP
AND (strftime('%Y', ORDER_DATE) = '2007'))
GROUP BY REP, NAME;

Слайд 11 Домашнее задание 4
Вывести только те товары, для которых

Домашнее задание 4Вывести только те товары, для которых количество на складе

количество на складе меньше на 20%, чем общее количество

этого товара, которое было сделано в заказах. Вывести (DESCRIPTION)

Слайд 12 Домашнее задание 4 sqlite
select DESCRIPTION
from PRODUCTS join (
select

Домашнее задание 4 sqlite	select DESCRIPTION	from PRODUCTS join (		select MFR, PRODUCT, sum(QTY)

MFR, PRODUCT, sum(QTY) as sum_qty
from ORDERS
group by MFR, PRODUCT
)

on (MFR_ID = MFR and trim(PRODUCT_ID) = trim(PRODUCT))
where (QTY_ON_HAND = 0.8 * sum_qty);

Слайд 13 Домашнее задание 4 sqlite
SELECT DESCRIPTION
FROM PRODUCTS
WHERE QTY_ON_HAND

Домашнее задание 4 sqliteSELECT DESCRIPTIONFROM PRODUCTS WHERE QTY_ON_HAND = 0.8 *

= 0.8 * (SELECT SUM(QTY) FROM ORDERS

WHERE (MFR_ID = MFR
AND trim(PRODUCT_ID) = trim(PRODUCT)));

Слайд 14 Домашнее задание 4 oracle
SELECT DESCRIPTION
FROM PRODUCTS
WHERE QTY_ON_HAND

Домашнее задание 4 oracleSELECT DESCRIPTIONFROM PRODUCTS WHERE QTY_ON_HAND = 0.8 *

= 0.8 * (SELECT SUM(QTY) FROM ORDERS

WHERE (MFR_ID = MFR
AND PRODUCT_ID = PRODUCT));

Слайд 15 Домашнее задание 5
Для каждого дня, когда был совершен

Домашнее задание 5Для каждого дня, когда был совершен заказ или принят

заказ или принят сотрудник, рассчитать абсолютную разницу между количеством

сотрудником и количеством заказов, сделанных в этот день. В выводе должно быть (date, abs_diff)

Слайд 16 Домашнее задание 5 oracle
select date, abs(cnt) as abs_diff
from

Домашнее задание 5 oracle	select date, abs(cnt) as abs_diff	from (		select HIRE_DATE as

(
select HIRE_DATE as date, count(*) as cnt
from SALESREPS
group by

HIRE_DATE
union
select ORDER_DATE as date, -count(*) as cnt
from ORDERS
group by ORDER_DATE
)
group by date;

Слайд 17 Домашнее задание 6
* Учитывая условия задачи 5 найти

Домашнее задание 6* Учитывая условия задачи 5 найти даты с минимальными

даты с минимальными и максимальными разницами в заказах. В

выводе должно быть (date, abs_diff).

Слайд 18 Домашнее задание 6
select date, abs(sum(val_hire)-sum(val_order)) as abs_diff
from (
select

Домашнее задание 6	select date, abs(sum(val_hire)-sum(val_order)) as abs_diff	from (		select HIRE_DATE as date,

HIRE_DATE as date, count(*) as val_hire, 0 as val_order
from

SALESREPS
group by HIRE_DATE
union
select ORDER_DATE as date, 0 as val_hire, count(*) as val_order
from ORDERS
group by ORDER_DATE
)
group by date
-- продолжение на след слайде

Слайд 19 Домашнее задание 6
having abs_diff in (
/* Поиск минимума

Домашнее задание 6having abs_diff in (		/* Поиск минимума среди абсолютной разности

среди абсолютной разности */
select min(abs_diff) as val
from (
select date,

abs(sum(val_hire)-sum(val_order)) as abs_diff
from (
select HIRE_DATE as date, count(*) as val_hire, 0 as val_order
from SALESREPS
group by HIRE_DATE
union
select ORDER_DATE as date, 0 as val_hire, count(*) as val_order
from ORDERS
group by ORDER_DATE
)
group by date
) – продолжение на след слайде

Слайд 20 Домашнее задание 6
union
/* Поиск максимума среди абсолютной разности

Домашнее задание 6		union		/* Поиск максимума среди абсолютной разности */		select max(abs_diff) as

*/
select max(abs_diff) as val
from (
select date, abs(sum(val_hire)-sum(val_order)) as abs_diff
from

(
select HIRE_DATE as date, count(*) as val_hire, 0 as val_order
from SALESREPS
group by HIRE_DATE
union
select ORDER_DATE as date, 0 as val_hire, count(*) as val_order
from ORDERS
group by ORDER_DATE
)
group by date
)
);

Слайд 21 Домашнее задание 6
WITH DIFF_CALC
AS
(
select date, abs(cnt) as

Домашнее задание 6WITH DIFF_CALCAS (	select date, abs(cnt) as abs_diff	from (		select HIRE_DATE

abs_diff
from (
select HIRE_DATE as date, count(*) as cnt
from SALESREPS
group

by HIRE_DATE
union
select ORDER_DATE as date, -count(*) as cnt
from ORDERS
group by ORDER_DATE
)
group by date
)
SELECT date, abs_diff
FROM DIFF_CALC
WHERE abs_diff = (SELECT max(abs_diff) FROM DIFF_CALC)
OR abs_diff = (SELECT min(abs_diff) FROM DIFF_CALC);


Слайд 22 Домашнее задание 6
SELECT date, abs_diff
FROM hw3_t5_tmp
WHERE abs_diff

Домашнее задание 6SELECT date, abs_diffFROM hw3_t5_tmp WHERE abs_diff = (SELECT max(abs_diff)

= (SELECT max(abs_diff) FROM hw3_t5_tmp)
OR abs_diff = (SELECT min(abs_diff)

FROM hw3_t5_tmp);

Слайд 23 Домашнее задание 7
Вывести только те товары, по которым

Домашнее задание 7Вывести только те товары, по которым было совершенно менее,

было совершенно менее, чем 3 заказа и сумма каждого

из заказов была не более, чем 4000, а общая сумма заказов менее 9000;

Слайд 24 Домашнее задание 7
SELECT DESCRIPTION
FROM PRODUCTS
WHERE NOT EXISTS
(
SELECT

Домашнее задание 7SELECT DESCRIPTIONFROM PRODUCTSWHERE NOT EXISTS (SELECT 1FROM ORDERS WHERE

1
FROM ORDERS
WHERE MFR_ID = MFR
AND TRIM(PRODUCT_ID) =

TRIM(PRODUCT)
AND AMOUNT > 4000
)
AND 3 > (SELECT COUNT(*)
FROM ORDERS
WHERE MFR_ID = MFR
AND TRIM(PRODUCT_ID) = TRIM(PRODUCT) )
AND 9000 > (SELECT SUM(AMOUNT)
FROM ORDERS
WHERE MFR_ID = MFR
AND TRIM(PRODUCT_ID) = TRIM(PRODUCT) );

Слайд 25 Обработка транзакций
Часто база данных должна обрабатывать события, которые

Обработка транзакцийЧасто база данных должна обрабатывать события, которые приводят более чем

приводят более чем к одному изменению в Базе Данных.



Слайд 26 Обработка транзакций
Рассмотрим событие – прием нового заказа от

Обработка транзакцийРассмотрим событие – прием нового заказа от клиента Добавление нового

клиента
Добавление нового заказа в таблицу ORDERS
Обновление фактического объема

продаж для служащего, принявшего заказ
Обновление фактического объема продаж для офиса, в котором работает данный служащий
Обновление количества товара, имеющегося в наличие

Слайд 27 Обработка транзакций
Для избегания нарушений целостности базы данных, четыре

Обработка транзакцийДля избегания нарушений целостности базы данных, четыре указанных изменения следует выполнить как единое целое.

указанных изменения следует выполнить как единое целое.


Слайд 28 Обработка транзакций
Для избегания нарушений целостности базы данных, четыре

Обработка транзакцийДля избегания нарушений целостности базы данных, четыре указанных изменения следует

указанных изменения следует выполнить как единое целое.
Допустим произошел системный

сбой или другая ошибка.
Тогда одна часть изменений была внесена, а другая нет. Это приводит к нарушению целостности хранимых данных и при последующих вычислениях результаты окажутся неверными.


Слайд 29 Обработка транзакций
Изменения базы данных, которые были вызваны одним

Обработка транзакцийИзменения базы данных, которые были вызваны одним событием, необходимо вносить

событием, необходимо вносить по принципу “Всё или ничего”.
SQL обеспечивает

такое поведение посредством возможностей обработки транзакций.


Слайд 30 Обработка транзакций
Транзакция – это несколько последовательных инструкций SQL,

Обработка транзакцийТранзакция – это несколько последовательных инструкций SQL, которые вместе образуют

которые вместе образуют логическую единицу работы (unit of work).


Слайд 31 Обработка транзакций
Транзакция – это несколько последовательных инструкций SQL,

Обработка транзакцийТранзакция – это несколько последовательных инструкций SQL, которые вместе образуют

которые вместе образуют логическую единицу работы (unit of work).
Инструкции,

входящие в транзакцию, обычно тесно связаны между собой и выполняют взаимосвязанные действия.

Слайд 32 Обработка транзакций
Группировка инструкций в единую транзакцию указывает СУБД,

Обработка транзакцийГруппировка инструкций в единую транзакцию указывает СУБД, что вся их

что вся их последовательность должна выполняться так, чтобы пройти

так называемый ACID-тест.
Atomic (атомарность)
Consistent (целостность)
Isolated (изолированность)
Durable (постоянство)

Слайд 33 Обработка транзакций
Atomic (Атомарность). “Все, или ничего”. Выполняются успешно

Обработка транзакцийAtomic (Атомарность). “Все, или ничего”. Выполняются успешно либо все операции

либо все операции транзакции, либо не выполняется ни одна

из них. Если выполнены лишь некоторые инструкции, то транзакция оказывается неуспешной, и в результате будет выполнен откат выполненных инструкций. Только если все инструкции выполнены успешно, то тогда транзакция может рассматриваться как завершенная, а ее результаты фиксируются в БД.

Слайд 34 Обработка транзакций
Consistent (Целостность). Транзакций должна переводить БД из

Обработка транзакцийConsistent (Целостность). Транзакций должна переводить БД из одного согласованного состояния

одного согласованного состояния в другое. База данных должна быть

в согласованном состоянии по окончании каждой транзакции, а это означает, что должны выполняться все правила и ограничения. Ни один пользователь не должен иметь доступ к данным, несогласованным из-за незавершенности транзакции.

Слайд 35 Обработка транзакций
Isolated (Изолированность). Каждая транзакция должна выполняться сама

Обработка транзакцийIsolated (Изолированность). Каждая транзакция должна выполняться сама по себе, без

по себе, без взаимодействия с другими транзакциями. Для этого

ни одна транзакция не должна работать с изменениями, вносимыми другой транзакцией, пока та не будет завершена.

Слайд 36 Обработка транзакций
Durable (Постоянство). По завершении транзакции все внесенные

Обработка транзакцийDurable (Постоянство). По завершении транзакции все внесенные ею изменения должны

ею изменения должны быть сохранены. Данные должны быть в

согласованном состоянии, даже если по окончании транзакции произойдет аппаратный или программный сбой. В ООП программировании это называется персистентность (persistence).

Слайд 37 Обработка транзакций
Пример транзакций:
Прием заказа. Программа ввода заказа должна:
Выполнить

Обработка транзакцийПример транзакций:Прием заказа. Программа ввода заказа должна:Выполнить запрос к Products

запрос к Products и проверить наличие товара на складе.
Добавить

заказ в таблицу ORDERS
Обновить таблицу PRODUCTS, вычтя заказанное кол-во товара из кол-ва товара, имеющегося в наличии;

Слайд 38 Обработка транзакций
Пример транзакций:
Прием заказа. Программа ввода заказа должна:
(d)

Обработка транзакцийПример транзакций:Прием заказа. Программа ввода заказа должна:(d) Обновить таблицу SALESREPS,

Обновить таблицу SALESREPS, добавив стоимость заказа к объему продаж

служащего, принявшего заказ;
(e) Обновить таблицу OFFICES, добавив стоимость заказа к объему продаж офиса, в котором работает служащий.

Слайд 39 Обработка транзакций
Пример транзакций:
Отмена заказа.
Удалить заказ из таблицы

Обработка транзакцийПример транзакций:Отмена заказа. Удалить заказ из таблицы ORDERS.Обновить таблицу PRODUCTS,

ORDERS.
Обновить таблицу PRODUCTS, откорректировав кол-во товара, имеющегося в наличии.
Обновить

таблицу SALESREPS, вычтя стоимость заказа из объема продаж служащего;
Обновить таблицу OFFICES, вычтя стоимость заказа из объема продаж офиса.

Слайд 40 Обработка транзакций
Пример транзакций:
Перевод клиента.
Обновить таблицу CUSTOMERS;
Обновить таблицу

Обработка транзакцийПример транзакций:Перевод клиента. Обновить таблицу CUSTOMERS;Обновить таблицу ORDERS, изменив имя

ORDERS, изменив имя служащего, ответственного за заказы данного клиента;
Обновить

таблицу SALESREPS, уменьшив план для служащего, теряющего клиента;
Обновить таблицу SALESREPS, увеличив план служащего, приобретающего клиента.

Слайд 41 Обработка транзакций
Инструкции, входящие в транзакцию, выполняются атомарно,

Обработка транзакций Инструкции, входящие в транзакцию, выполняются атомарно, как единое неделимое

как единое неделимое целое. Либо все инструкции будут выполнены

успешно, либо ни одна из них не должны быть выполнена.

Слайд 42 Обработка транзакций
SELECT
SELECT
SELECT
SELECT
UPDATE
UPDATE
UPDATE
UPDATE
UPDATE
UPDATE
Аппаратный сбой
SAVEPOINT
DELETE
DELETE
DELETE
Программная ошибка
СУБД
отменяет все
изменения
СУБД
отменяет все
изменения
Программная ошибка
СУБД
отменяет все
изменения
INSERT
Состояние

Обработка транзакцийSELECTSELECTSELECTSELECTUPDATEUPDATEUPDATEUPDATEUPDATEUPDATEАппаратный сбойSAVEPOINTDELETEDELETEDELETEПрограммная ошибкаСУБДотменяет всеизмененияСУБДотменяет всеизмененияПрограммная ошибкаСУБДотменяет всеизмененияINSERTСостояние БД после транзакции

БД
после транзакции


Слайд 43 Модель транзакции ANSI/ISO SQL
В стандарте ANSI/ISO

Модель транзакции ANSI/ISO SQL В стандарте ANSI/ISO определена модель транзацкций SQL,

определена модель транзацкций SQL, а также семь инструкций для

поддержки работы с транзакциями

Слайд 44 Модель транзакции ANSI/ISO SQL
- START TRANSACTION. Устанавливает

Модель транзакции ANSI/ISO SQL - START TRANSACTION. Устанавливает свойства новой транзакции и запускает транзакцию

свойства новой транзакции и запускает транзакцию


Слайд 45 Модель транзакции ANSI/ISO SQL
START TRANSACTION.
SET TRANSACTION.

Модель транзакции ANSI/ISO SQL START TRANSACTION. SET TRANSACTION. Устанавливает свойства очередной

Устанавливает свойства очередной выполняемой транзакции. Не влияет на текущую

выполняемую транзакцию.

Слайд 46 Модель транзакции ANSI/ISO SQL
START TRANSACTION.
SET TRANSACTION.

Модель транзакции ANSI/ISO SQL START TRANSACTION. SET TRANSACTION. SET CONSTRAINTS. Устанавливает


SET CONSTRAINTS. Устанавливает режим ограничений в текущей транзакции. Режим

ограничений управляет тем, применяется ли ограничение немедленно или откладывается до более позднее момента.

Слайд 47 Модель транзакции ANSI/ISO SQL
START TRANSACTION.
SET TRANSACTION.

Модель транзакции ANSI/ISO SQL START TRANSACTION. SET TRANSACTION. SET CONSTRAINTS. SAVEPOINT.


SET CONSTRAINTS.
SAVEPOINT. Создает точку сохранения в пределах транзакции.

Точка сохранения представляет собой место в посл-ти событий транзакции, к-ое может выступать в качестве промежуточной точки восстановления. Откат текущей транзакции может быть выполнен не к началу транзакции, а к точке сохранения.

Слайд 48 Модель транзакции ANSI/ISO SQL
START TRANSACTION.
SET TRANSACTION.

Модель транзакции ANSI/ISO SQL START TRANSACTION. SET TRANSACTION. SET CONSTRAINTS. SAVEPOINT.


SET CONSTRAINTS.
SAVEPOINT.
RELEASE SAVEPOINT. Освобождает точку сохранения и

все ресурсы, которые она могла захватить.

Слайд 49 Модель транзакции ANSI/ISO SQL
COMMIT. Завершает успешную транзакцию

Модель транзакции ANSI/ISO SQL COMMIT. Завершает успешную транзакцию и сохраняет все

и сохраняет все внесенные изменения в базе данных.


Слайд 50 Модель транзакции ANSI/ISO SQL
ROLLBACK. При использовании без

Модель транзакции ANSI/ISO SQL ROLLBACK. При использовании без точки сохранения прекращает

точки сохранения прекращает неудачную транзакцию и выполняет откат всех

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

Слайд 51 Инструкции SET TRANSACTION и START TRANSACTION

Инструкции SET TRANSACTION и START TRANSACTION

Слайд 52 Инструкции SAVEPOINT и RELEASE SAVEPOINT
SAVEPOINT имя_точки_сохранения;
Преимущество – возможность

Инструкции SAVEPOINT и RELEASE SAVEPOINTSAVEPOINT имя_точки_сохранения;Преимущество – возможность отката части транзакции

отката части транзакции в случае небольших и потенциально восстановительных

ошибок.
Пример – приложение для ввода заказов может создавать точку сохранения после каждой введенной строки заказа. Если добавление новой строки из заказа приводит к превышению лимита кредита, приложение может выполнить откат к т. сохранения, установленной непосредственно перед строкой.

Слайд 53 Инструкции SAVEPOINT и RELEASE SAVEPOINT
SAVEPOINT имя_точки_сохранения;
Недостаток – потенциальное

Инструкции SAVEPOINT и RELEASE SAVEPOINTSAVEPOINT имя_точки_сохранения;Недостаток – потенциальное использование большого кол-ва ресурсов. RELEASE SAVEPOINT имя_точки_сохранения;

использование большого кол-ва ресурсов.
RELEASE SAVEPOINT имя_точки_сохранения;


Слайд 54 Инструкции COMMIT и ROLLBACK
COMMIT [WORK] [AND [NO] CHAIN]
ROLLBACK

Инструкции COMMIT и ROLLBACKCOMMIT [WORK] [AND [NO] CHAIN]ROLLBACK [WORK] [AND [NO]

[WORK] [AND [NO] CHAIN] [TO SAVEPOINT имя_точки_сохранения]
WORK. Ключевое слово.

Включено в стандарт для совместимости.
AND [NO] CHAIN. Передача свойств следующей транзакции.
TO SAVEPOINT. Указание в какое место произвести откат

Слайд 55 Пример COMMIT
Изменить объем заказа 113051 с 4 до

Пример COMMITИзменить объем заказа 113051 с 4 до 10 единиц, что

10 единиц, что повышает его сумму с $1458 до

$3550. Заказ на товар QSA-XK47 был принят Ларри Фитчем (ид 108), к-ый работает в Л.А. (21).
UPDATE ORDERS
SET QTY = 10, AMOUNT = 3550.00
WHERE ORDER_NUM = 113051;

UPDATE SALESREPS
SET SALES = SALES – 1458.00 + 3550.00
WHERE EMPL_NUM = 108;

Слайд 56 Пример COMMIT
UPDATE OFFICES
SET SALES = SALES –

Пример COMMITUPDATE OFFICES SET SALES = SALES – 1458.00 + 3550.00WHERE

1458.00 + 3550.00
WHERE OFFICE = 21;

UPDATE PRODUCTS
SET QTY_ON_HAND

= QTY_ON_HAND + 4 – 10
WHERE MFR_ID = ‘QSA’
AND PRODUCT_ID = ‘XK47’;
-- подтверждение
COMMIT WORK;

Слайд 57 Пример ROLLBACK
UPDATE ORDERS
SET QTY = 10, AMOUNT

Пример ROLLBACKUPDATE ORDERS SET QTY = 10, AMOUNT = 3550.00WHERE ORDER_NUM

= 3550.00
WHERE ORDER_NUM = 113051;

UPDATE SALESREPS
SET SALES = SALES

– 1458.00 + 3550.00
WHERE EMPL_NUM = 108


Слайд 58 Пример ROLLBACK
UPDATE OFFICES
SET SALES = SALES –

Пример ROLLBACKUPDATE OFFICES SET SALES = SALES – 1458.00 + 3550.00WHERE

1458.00 + 3550.00
WHERE OFFICE = 21;

UPDATE PRODUCTS
SET QTY_ON_HAND

= QTY_ON_HAND + 4 – 10
WHERE MFR_ID = ‘QAS’
AND PRODUCT_ID = ‘XK47’
-- производитель не QAS, а QSA
ROLLBACK WORK;


Слайд 59 Транзакции и работа в многопользовательском режиме
Если с БД

Транзакции и работа в многопользовательском режимеЕсли с БД работают одновременно двое

работают одновременно двое или более пользователей, СУБД должна не

только осуществлять восстановление базы данных после отмены транзакций, но и гарантировать, что пользователи не будут мешать друг другу.
В идеальном случае каждый пользователь должен работать с БД так, как если бы он не имел к ней многопользовательский доступ, и не должен беспокоиться о действиях других пользователей.

Слайд 60 DIRTY WRITE P0
Транзакция T1 модифицирует строку. Другая транзакция

DIRTY WRITE P0Транзакция T1 модифицирует строку. Другая транзакция T2 также модифицирует

T2 также модифицирует эту строку до COMMIT или ROLLBACK

от T1. Если T1 или T2 произведет ROLLBACK не ясно, какие данные должны быть корректны.

Слайд 61 DIRTY READ P1
SELECT QTY_ON_HAND
FROM PRODUCTS
Ответ:139
UPDATE PRODUCTS
SET

DIRTY READ P1SELECT QTY_ON_HAND FROM PRODUCTS Ответ:139UPDATE PRODUCTSSET QTY_ON_HAND = 39SELECT

QTY_ON_HAND = 39
SELECT QTY_ON_HAND
FROM PRODUCTS
Ответ:39
Не принят заказ

на 125 шт.

ROLLBACK


Слайд 62 P2 NONREPEATABLE READ
SELECT QTY_ON_HAND
FROM PRODUCTS
Ответ:139
SELECT QTY_ON_HAND

P2 NONREPEATABLE READSELECT QTY_ON_HAND FROM PRODUCTS Ответ:139SELECT QTY_ON_HAND FROM PRODUCTS Ответ:139SELECT QTY_ON_HAND FROM PRODUCTS Ответ:39


FROM PRODUCTS
Ответ:139
SELECT QTY_ON_HAND
FROM PRODUCTS
Ответ:39


Слайд 63 P3 PHANTOM
SELECT *
FROM ORDERS
112962,31500
113012,3745
INSERT INTO VALUES
(118102, ..,

P3 PHANTOMSELECT * FROM ORDERS112962,31500113012,3745INSERT INTO VALUES(118102, .., 5.000)COMMITSELECT * FROM ORDERS112962,31500113012,3745118102,5000

5.000)
COMMIT
SELECT *
FROM ORDERS
112962,31500
113012,3745
118102,5000


Слайд 64 P4 LOST UPDATE
SELECT QTY_ON_HAND
FROM PRODUCTS
Ответ:139
UPDATE PRODUCTS
SET

P4 LOST UPDATESELECT QTY_ON_HAND FROM PRODUCTS Ответ:139UPDATE PRODUCTSSET QTY_ON_HAND = 39SELECT

QTY_ON_HAND = 39
SELECT QTY_ON_HAND
FROM PRODUCTS
Ответ:39
Принят заказ на

125 шт.

UPDATE PRODUCTS
SET QTY_ON_HAND = 14


Слайд 65 Блокировка при параллельном выполнении 2 транзакций

Блокировка при параллельном выполнении 2 транзакций

Слайд 66 Уровни блокировки
На уровне БД
На уровне таблицы
На уровне страниц
На

Уровни блокировкиНа уровне БДНа уровне таблицыНа уровне страницНа уровне строк

уровне строк


Слайд 67 Виды блокировок
Блокировка с обеспечением совместного доступа, или блокировка

Виды блокировокБлокировка с обеспечением совместного доступа, или блокировка без монополизации (shared

без монополизации (shared lock). Когда транзакция извлекает информацию из

базы данных, СУБД применяет блокировку без монополизации. При этом другие транзакции, выполняемые параллельно, могут извлекать те же данные.

Слайд 68 Виды блокировок
Монопольная, или исключающая блокировка (exclusive lock). Когда

Виды блокировокМонопольная, или исключающая блокировка (exclusive lock). Когда транзакция обновляет информацию

транзакция обновляет информацию в БД, СУБД применяет исключающую блокировку.

Если транзакция монопольно заблокировала какие-либо данные, другие транзакции не могут обращаться к ним ни для выборки, ни для записи.

Слайд 69 Правила применения блокировок

Правила применения блокировок

Слайд 70 Виды блокировок

Виды блокировок

Слайд 71 Виды блокировок

Виды блокировок

Слайд 72 Усовершенствованные методы блокировок
Явная блокировка.
Уровни изоляции.
Параметры блокировки.

Усовершенствованные методы блокировокЯвная блокировка.Уровни изоляции.Параметры блокировки.

Слайд 73 Уровни изоляции

Уровни изоляции

Слайд 74 Архитектура управления версиями

Архитектура управления версиями

Слайд 75 Резюме
В РСУБД транзакция представляет собой логическую единицу работы.

РезюмеВ РСУБД транзакция представляет собой логическую единицу работы. Транзакция состоит из

Транзакция состоит из последовательности инструкций SQL, которые СУБД выполняет

как одно целое.
Инструкции SET TRANSACTION и START TRANSACTION могут использоваться для установки уровня изоляции и уровня доступа транзакций
Инструкций SAVEPOINT создает промежуточную точку восстановления внутри транзакции.

Слайд 76 Резюме
Инструкция RELEASE SAVEPOINT удаляет точку сохранения и освобождает

РезюмеИнструкция RELEASE SAVEPOINT удаляет точку сохранения и освобождает захваченные ею ресурсы.Инструкция

захваченные ею ресурсы.
Инструкция COMMIT сообщает об успешном завершениии.
Инструкция ROLLBACK

предлагает СУБД отменить транзакцию и все изменения, уже внесенные в базу данных данной транзакции.
Транзакции играют ключевую роль при восстановлении базы данных после системного сбоя.

Слайд 77 Резюме
Транзакции играют ключевую роль при параллельном доступе к

РезюмеТранзакции играют ключевую роль при параллельном доступе к данным в многопользовательской

данным в многопользовательской базе данных.
Иногда конфликт с другой параллельной

транзакцией может привести к отмене транзакции не по ее вине. Приложение должно быть готово к решению этой проблемы в случае ее возникновения.
Одной из наиболее сложных областей использования и настройки большей большой базы данных является управление транзакциями и их влияние на производительность СУБД.

Слайд 78 Резюме
Многие СУБД для обработки параллельных транзакций применяют методику

РезюмеМногие СУБД для обработки параллельных транзакций применяют методику блокировки. Изменение параметров

блокировки. Изменение параметров блокировок и инструкции явной блокировки обеспечивают

возможность тонкой настройки обработки транзакций и повышения производительности баз данных
Альтернативой блокировкам служит поддерживаемый рядом СУБД метод управления версиями

Слайд 79 Создание базы данных
- Инструкции SELECT, INSERT, UPDATE, COMMIT,

Создание базы данных- Инструкции SELECT, INSERT, UPDATE, COMMIT, ROLLBACK, DELETE предназначены

ROLLBACK, DELETE предназначены для обработки данных. Эти инструкции называются

языком обработки данных или DML (Data Manipulation Language). Инструкции DML могут модифицировать информацию, хранимую в базе данных, но не могут модифицировать ее структуру.

Слайд 80 Создание базы данных
- Для изменения структуры базы данных

Создание базы данных- Для изменения структуры базы данных предназначен другой набор

предназначен другой набор инструкций SQL, так называемый язык определения

данных или DDL (Data Definition Language).

Слайд 81 DDL
Определить структуру новой таблицы и создать ее;
Удалить таблицу,

DDLОпределить структуру новой таблицы и создать ее;Удалить таблицу, которая больше не

которая больше не нужна;
Изменить определение существующей таблицы;
Определить виртуальную таблицу

(или представление) данных;
Обеспечить безопасность базы данных;
Создать индекс для ускорения доступа к таблице
Управлять физическим размещением данных

Слайд 82 DDL
Ядро языка определения данных образуют три команды:
CREATE (создать),

DDLЯдро языка определения данных образуют три команды:CREATE (создать), позволяющая определить и

позволяющая определить и создать объект базы данных;
DROP (удалить), служащая

для удаления существующего объекта базы данных;
ALTER (изменить), посредством которой можно изменить определение объекта базы данных;

Слайд 83 Создание базы данных
CREATE DATABASE


DROP DATABASE

Создание базы данныхCREATE DATABASEDROP DATABASE

Слайд 84 Определение таблиц
В реляционной базе данных наиболее важным элементом

Определение таблицВ реляционной базе данных наиболее важным элементом ее структуры является

ее структуры является таблица
Таблица является проекцией отношения из реляционной

алгебры на реальные базы данных.

Слайд 85 Создание таблицы (CREATE TABLE)

Создание таблицы (CREATE TABLE)

Слайд 86 Определения столбцов
- Имя столбца. Используется для обращения к

Определения столбцов- Имя столбца. Используется для обращения к столбцу в инструкциях

столбцу в инструкциях SQL. Каждый столбец в таблице должен

иметь уникальное имя, но в разных таблицах имена столбцов могут совпадать.

Слайд 87 Определения столбцов
Тип данных. Указывает тип столбца. Иногда указывается

Определения столбцовТип данных. Указывает тип столбца. Иногда указывается доп. информация, такая

доп. информация, такая как длина или число десятичных разрядов.


Слайд 88 Определения столбцов
Обязательность данных. Определяет, допускаются ли в данном

Определения столбцовОбязательность данных. Определяет, допускаются ли в данном столбце значения NULL.Значения

столбце значения NULL.
Значения по умолчанию. Это необязательное значение по

умолчанию, которое заносится в том случае, если в инструкции INSERT для таблицы не указано значение для данного столбца.

Слайд 89 Пример ORACLE
CREATE TABLE OFFICES
(
OFFICE NUMERIC(10, 0) NOT NULL,
CITY

Пример ORACLECREATE TABLE OFFICES(	OFFICE NUMERIC(10, 0) NOT NULL,	CITY VARCHAR2(15) 	NOT NULL,	REGION

VARCHAR2(15) NOT NULL,
REGION VARCHAR2(10) NOT NULL,
MGR NUMERIC (10,0),
TARGET NUMERIC(10, 2),
SALES

NUMERIC(10, 2) NOT NULL
);

Слайд 90 Пример ORACLE
CREATE TABLE ORDERS
(
ORDER_NUM NUMERIC(10, 0) NOT

Пример ORACLECREATE TABLE ORDERS (	ORDER_NUM NUMERIC(10, 0) NOT NULL,	ORDER_DATE DATE NOT

NULL,
ORDER_DATE DATE NOT NULL,
CUST NUMERIC(10, 0) NOT NULL,
REP NUMERIC(10,

0),
MFR CHAR(3) NOT NULL,
PRODUCT CHAR(5) NOT NULL,
QTY NUMERIC(10, 0) NOT NULL,
AMOUNT NUMERIC(9,2) NOT NULL
);

Слайд 91 Пример ORACLE
CREATE TABLE ORDERS
(
ORDER_NUM NUMERIC(10, 0) NOT

Пример ORACLECREATE TABLE ORDERS (	ORDER_NUM NUMERIC(10, 0) NOT NULL,	ORDER_DATE DATE NOT

NULL,
ORDER_DATE DATE NOT NULL,
CUST NUMERIC(10, 0) NOT NULL,
REP NUMERIC(10,

0),
MFR CHAR(3) NOT NULL,
PRODUCT CHAR(5) NOT NULL,
QTY NUMERIC(10, 0) NOT NULL,
AMOUNT NUMERIC(9,2) NOT NULL
);

Слайд 92 Значения по умолчанию и отсутствующие значения
CREATE TABLE OFFICES

Значения по умолчанию и отсутствующие значенияCREATE TABLE OFFICES (	OFFICE NUMERIC(10,0) NOT


(
OFFICE NUMERIC(10,0) NOT NULL,
CITY VARCHAR2(15) NOT NULL,
REGION VARCHAR2(10) NOT NULL

DEFAULT 'Eastern',
MGR NUMERIC(10,0) DEFAULT 106,
TARGET NUMERIC(9,2) DEFAULT NULL,
SALES NUMERIC(9,2) NOT NULL DEFAULT 0.00
);

Слайд 93 Ограничения

Ограничения

Слайд 94 Определение первичного ключа
В предложении PRIMARY KEY задается столбец

Определение первичного ключаВ предложении PRIMARY KEY задается столбец или столбцы, которые

или столбцы, которые образуют первичный ключ таблицы. Этот столбец

служит в качестве уникального идентификатора строк таблицы. СУБД автоматически следит, чтобы первичный ключ содержал уникальные значения. Также должно быть указано, что значение NOT NULL

Слайд 95 Определение внешнего ключа

Определение внешнего ключа

Слайд 96 Определение внешнего ключа
Стоблец или столбцы создаваемой таблицы, которые

Определение внешнего ключаСтоблец или столбцы создаваемой таблицы, которые создают внешний ключ.Таблица,

создают внешний ключ.
Таблица, связь с которой создает внешний ключ.

Это родительская таблица; Определяемая таблица в данном отношении является дочерней.
Необязательный список имен столбцов родительской таблицы, которые соответствуют столбцам внешнего ключа определяемой таблицы. Если имена столбцов опущены, в родительской таблице обязаны быть столбцы с именами, идентичными именам столбцов во внешнем ключе.

Слайд 97 Определение внешнего ключа
Необязательное имя для этого отношения; оно

Определение внешнего ключаНеобязательное имя для этого отношения; оно не используется в

не используется в инструкциях SQL, но может появляться в

сообщениях об ошибках и потребуется в дальнейшем, если будет необходимо удалить внешний ключ;
Как СУБД должна трактовать значения NULL в одном или нескольких столбцах внешнего ключа при связывании его со строками таблицы-предка


Слайд 98 Определение внешнего ключа
Необязательное правило удаления для данного отношения

Определение внешнего ключаНеобязательное правило удаления для данного отношения (CASCADE, SET NULL,

(CASCADE, SET NULL, SET DEFAULT, NO ACTION), которое определяет

действие, предпринимаемое при удалении строки родительской строки;
Необязательное правило обновления для данного отношения, которое определяет действие, предпринимаемое при обновлении первичного ключа в строке родительской таблицы;

Слайд 99 Определение внешнего ключа
Необязательное условие на значения, которое ограничивает

Определение внешнего ключаНеобязательное условие на значения, которое ограничивает данные в таблице

данные в таблице так, чтобы они отвечали определенному критерию

отбора.

Слайд 100 Пример с PRIMARY и FOREIGN KEY
CREATE TABLE ORDERS
(
ORDER_NUM

Пример с PRIMARY и FOREIGN KEYCREATE TABLE ORDERS(	ORDER_NUM INTEGER NOT NULL,	ORDER_DATE

INTEGER NOT NULL,
ORDER_DATE DATE NOT NULL,
CUST INTEGER NOT NULL,


REP INTEGER,
MFR CHAR(3) NOT NULL,
PRODUCT CHAR(5) NOT NULL,
QTY INTEGER NOT NULL,
AMOUNT DECIMAL(9,2) NOT NULL,

Слайд 101 Пример с PRIMARY и FOREIGN KEY
PRIMARY KEY (ORDER_NUM),

Пример с PRIMARY и FOREIGN KEYPRIMARY KEY (ORDER_NUM), CONSTRAINT PLACEDBY FOREIGN

CONSTRAINT PLACEDBY FOREIGN KEY (CUST)
REFERENCES CUSTOMERS(CUST_NUM)
ON

DELETE CASCADE,
CONSTRAINT TAKENBY FOREIGN KEY (REP)
REFERENCES SALESREPS(EMPL_NUM)
ON DELETE SET NULL,
CONSTRAINT ISFOR FOREIGN KEY (MFR, PRODUCT)
REFERENCES PRODUCTS(MFR_ID, PRODUCT_ID));

Слайд 102 Условия уникальности
Стандарт SQL определяет, что условия уникальности также

Условия уникальностиСтандарт SQL определяет, что условия уникальности также задаются в инструкции

задаются в инструкции CREATE TABLE, с применением предложения UNIQUE.


Слайд 103 Пример с UNIQUE
CREATE TABLE OFFICES
( OFFICE INTEGER NOT NULL,

Пример с UNIQUECREATE TABLE OFFICES(	OFFICE INTEGER NOT NULL, CITY VARCHAR(15) NOT

CITY VARCHAR(15) NOT NULL,
REGION VARCHAR(10) NOT

NULL,
MGR INTEGER,
TARGET DECIMAL(9,2),
SALES DECIMAL(9,2) NOT NULL,
PRIMARY KEY (OFFICE),
CONSTRAINT HASMGR
FOREIGN KEY (MGR)
REFERENCES SALESREPS (EMPL_NUM)
ON DELETE SET NULL,
UNIQUE(CITY)) ;

Слайд 104 Ограничения на значения столбцов
Ограничение на значения столбцов

Ограничения на значения столбцов Ограничение на значения столбцов связано с инструкцией CHECK.

связано с инструкцией CHECK.


Слайд 105 Пример с CHECK
CREATE TABLE OFFICES
(OFFICE

Пример с CHECKCREATE TABLE OFFICES  (OFFICE INTEGER NOT NULL,

INTEGER NOT NULL,
CITY VARCHAR(15) NOT

NULL,
REGION VARCHAR(10) NOT NULL,
MGR INTEGER,
TARGET DECIMAL(9,2),
SALES DECIMAL(9,2) NOT NULL,
PRIMARY KEY (OFFICE),
CHECK (TARGET >= 0.0));

Слайд 106 Удаление таблицы

Удаление таблицы

Слайд 107 Изменение определения таблицы
Добавить в каждую строку таблицы CUSTOMERS

Изменение определения таблицыДобавить в каждую строку таблицы CUSTOMERS имя и номер

имя и номер телефона служащего компании – клиента, через

которого поддерживается контакт, если необходимо использовать эту таблицу для связи с клиентами;
Добавить в таблицу PRODUCTS столбец с указанием минимального количества на складе, чтобы база данных могла автоматически предупреждать о том, что запас какого-либо товара стал меньше допустимого предела.

Слайд 108 Изменение определения таблицы
Сделать столбец REGION таблицы OFFICES внешним

Изменение определения таблицыСделать столбец REGION таблицы OFFICES внешним ключом для вновь

ключом для вновь созданной таблицы REGIONS, первичным ключом которой

является название региона;
Удалить определение внешнего ключа для столбца CUST таблицы ORDERS, связывающего ее с таблицей CUSTOMERS, и заменить определениями двух внешних ключей, связывающих столбец CUST с двумя вновь созданными таблицами CUST_INFO и ACCOUNT_INFO

Слайд 109 Изменение определения таблицы

Изменение определения таблицы

Слайд 110 Изменение определения таблицы
Добавить в таблицу определение столбца;
Удалить столбец

Изменение определения таблицыДобавить в таблицу определение столбца;Удалить столбец из таблицы;Изменить значение

из таблицы;
Изменить значение по умолчанию для какого-либо столбца;
Добавить или

удалить первичный ключ таблицы;
Добавить или удалить внешний ключ таблицы;
Добавить или удалить условие уникальности;
Добавить или удалить условие на значение;

Слайд 111 Добавление в таблицу столбцов
ALTER TABLE CUSTOMERS
ADD CONTACT_NAME VARCHAR(30);

ALTER

Добавление в таблицу столбцовALTER TABLE CUSTOMERSADD CONTACT_NAME VARCHAR(30);ALTER TABLE CUSTOMERSADD COLUMN

TABLE CUSTOMERS
ADD COLUMN CONTACT_PHONE CHAR(10);

ALTER TABLE PRODUCTS
ADD MIN_QTY INTEGER

NOT NULL DEFAULT 0;

Слайд 112 Удаление столбцов
ALTER TABLE CUSTOMERS
DROP CONTACT_NAME;

Удаление столбцовALTER TABLE CUSTOMERSDROP CONTACT_NAME;

Слайд 113 Изменения первичных и внешних ключей
ALTER TABLE OFFICES
ADD CONSTRAINT

Изменения первичных и внешних ключейALTER TABLE OFFICESADD CONSTRAINT INREGION FOREIGN KEY

INREGION
FOREIGN KEY (REGION)
REFERENCES REGIONS;

ALTER TABLE SALESREPS
DROP CONSTRAINT WORKSIN;

ALTER

TABLE OFFICES
DROP PRIMARY KEY;

Слайд 114 Основные понятия ER-диаграмм
Определение 1. Сущность - это класс однотипных объектов,

Основные понятия ER-диаграммОпределение 1. Сущность - это класс однотипных объектов, информация о которых должна быть учтена в модели.

информация о которых должна быть учтена в модели.



Слайд 115 Основные понятия ER-диаграмм
http://citforum.ru/database/dblearn/dblearn08.shtml
Статья по разделу

Основные понятия ER-диаграммhttp://citforum.ru/database/dblearn/dblearn08.shtml Статья по разделу

Слайд 116 Основные понятия ER-диаграмм
Определение 2. Экземпляр сущности - это конкретный представитель

Основные понятия ER-диаграммОпределение 2. Экземпляр сущности - это конкретный представитель данной сущности.Например, представителем

данной сущности.
Например, представителем сущности "Сотрудник" может быть "Сотрудник Иванов".
Экземпляры

сущностей должны быть различимы, т.е. сущности должны иметь некоторые свойства, уникальные для каждого экземпляра этой сущности.

Слайд 117 Основные понятия ER-диаграмм
Определение 3. Атрибут сущности - это именованная характеристика,

Основные понятия ER-диаграммОпределение 3. Атрибут сущности - это именованная характеристика, являющаяся некоторым свойством

являющаяся некоторым свойством сущности.
Наименование атрибута должно быть выражено существительным

в единственном числе (возможно, с характеризующими прилагательными).
Примерами атрибутов сущности "Сотрудник" могут быть такие атрибуты как "Табельный номер", "Фамилия", "Имя", "Отчество", "Должность", "Зарплата" и т.п.

Слайд 118 Основные понятия ER-диаграмм

Основные понятия ER-диаграмм

Слайд 119 Основные понятия ER-диаграмм
Определение 4. Ключ сущности - это неизбыточный набор атрибутов, значения

Основные понятия ER-диаграммОпределение 4. Ключ сущности - это неизбыточный набор атрибутов, значения которых в совокупности

которых в совокупности являются уникальными для каждого экземпляра сущности. Неизбыточность заключается

в том, что удаление любого атрибута из ключа нарушается его уникальность.
Сущность может иметь несколько различных ключей.

Слайд 120 Основные понятия ER-диаграмм

Основные понятия ER-диаграмм

Слайд 121 Основные понятия ER-диаграмм
Определение 5. Связь - это некоторая ассоциация между двумя сущностями.

Основные понятия ER-диаграммОпределение 5. Связь - это некоторая ассоциация между двумя сущностями. Одна сущность может

Одна сущность может быть связана с другой сущностью или

сама с собою.
Связи позволяют по одной сущности находить другие сущности, связанные с нею.
Например, связи между сущностями могут выражаться следующими фразами - "СОТРУДНИК может иметь несколько ДЕТЕЙ", "каждый СОТРУДНИК обязан числиться ровно в одном ОТДЕЛЕ".
Графически связь изображается линией, соединяющей две сущности:

Слайд 122 Основные понятия ER-диаграмм

Основные понятия ER-диаграмм

Слайд 123 Основные понятия ER-диаграмм
Каждая связь имеет два конца и

Основные понятия ER-диаграммКаждая связь имеет два конца и одно или два

одно или два наименования. Наименование обычно выражается в неопределенной

глагольной форме: "иметь", "принадлежать" и т.п. Каждое из наименований относится к своему концу связи. Иногда наименования не пишутся ввиду их очевидности.
Каждая связь может иметь один из следующих типов связи:


Слайд 124 Основные понятия ER-диаграмм

Основные понятия ER-диаграмм

Слайд 125 Основные понятия ER-диаграмм
Связь типа один-к-одному означает, что один экземпляр первой

Основные понятия ER-диаграммСвязь типа один-к-одному означает, что один экземпляр первой сущности (левой) связан

сущности (левой) связан с одним экземпляром второй сущности (правой).

Связь один-к-одному чаще всего свидетельствует о том, что на самом деле мы имеем всего одну сущность, неправильно разделенную на две.

Слайд 126 Основные понятия ER-диаграмм
Связь типа один-ко-многим означает, что один экземпляр первой

Основные понятия ER-диаграммСвязь типа один-ко-многим означает, что один экземпляр первой сущности (левой) связан

сущности (левой) связан с несколькими экземплярами второй сущности (правой).

Это наиболее часто используемый тип связи. Левая сущность (со стороны "один") называется родительской, правая (со стороны "много") - дочерней

Слайд 127 Основные понятия ER-диаграмм
Связь типа много-ко-многим означает, что каждый экземпляр первой

Основные понятия ER-диаграммСвязь типа много-ко-многим означает, что каждый экземпляр первой сущности может быть

сущности может быть связан с несколькими экземплярами второй сущности,

и каждый экземпляр второй сущности может быть связан с несколькими экземплярами первой сущности.

Слайд 128 Основные понятия ER-диаграмм
Каждая связь может иметь одну из

Основные понятия ER-диаграммКаждая связь может иметь одну из двух модальностей связи:

двух модальностей связи:


Слайд 129 Основные понятия ER-диаграмм
Модальность "может" означает, что экземпляр одной

Основные понятия ER-диаграммМодальность

сущности может быть связан с одним или несколькими экземплярами другой сущности, а

может быть и не связан ни с одним экземпляром.
Модальность "должен" означает, что экземпляр одной сущности обязан быть связан не менее чем с одним экземпляром другой сущности.
Связь может иметь разную модальность с разных концов

Слайд 130 Основные понятия ER-диаграмм
При разработке ER-моделей мы должны получить

Основные понятия ER-диаграммПри разработке ER-моделей мы должны получить следующую информацию о

следующую информацию о предметной области:
Список сущностей предметной области.
Список атрибутов

сущностей.
Описание взаимосвязей между сущностями.

Слайд 131 Основные понятия ER-диаграмм
Предположим, что перед нами стоит задача

Основные понятия ER-диаграммПредположим, что перед нами стоит задача разработать информационную систему

разработать информационную систему по заказу некоторой оптовой торговой фирмы.

В первую очередь мы должны изучить предметную область и процессы, происходящие в ней.

Слайд 132 Основные понятия ER-диаграмм
Например, выяснилось, что проектируемая система должна

Основные понятия ER-диаграммНапример, выяснилось, что проектируемая система должна выполнять следующие действия:Хранить

выполнять следующие действия:
Хранить информацию о покупателях.
Печатать накладные на отпущенные

товары.
Следить за наличием товаров на складе.

Слайд 133 Основные понятия ER-диаграмм
Выделим все существительные в этих предложениях

Основные понятия ER-диаграммВыделим все существительные в этих предложениях - это будут

- это будут потенциальные кандидаты на сущности и атрибуты,

и проанализируем их (непонятные термины будем выделять знаком вопроса):
Покупатель - явный кандидат на сущность.
Накладная - явный кандидат на сущность.
Товар - явный кандидат на сущность
(?)Склад - а вообще, сколько складов имеет фирма? Если несколько, то это будет кандидатом на новую сущность.
(?)Наличие товара – это, скорее всего, атрибут, но атрибут какой сущности?

Слайд 134 Основные понятия ER-диаграмм

Основные понятия ER-диаграмм

Слайд 135 Основные понятия ER-диаграмм
Формируем атрибуты сущности:
Каждый покупатель является юридическим

Основные понятия ER-диаграммФормируем атрибуты сущности:Каждый покупатель является юридическим лицом и имеет

лицом и имеет наименование, адрес, банковские реквизиты.
Каждый товар имеет

наименование, цену, а также характеризуется единицами измерения.
Каждая накладная имеет уникальный номер, дату выписки, список товаров с количествами и ценами, а также общую сумму накладной. Накладная выписывается с определенного склада и на определенного покупателя.
И т.п.

Слайд 136 Основные понятия ER-диаграмм

Основные понятия ER-диаграмм

Слайд 137 Основные понятия ER-диаграмм
Разработанный выше пример ER-диаграммы является примером концептуальной

Основные понятия ER-диаграммРазработанный выше пример ER-диаграммы является примером концептуальной диаграммы. Это означает,

диаграммы. Это означает, что диаграмма не учитывает особенности конкретной СУБД. По

данной концептуальной диаграмме можно построить физическую диаграмму, которая уже будут учитываться такие особенности СУБД, как допустимые типы и наименования полей и таблиц, ограничения целостности и т.п

Слайд 138 Основные понятия ER-диаграмм

Основные понятия ER-диаграмм

Слайд 139 Нормальные формы
Статья - https://habrahabr.ru/post/254773/

Нормальные формыСтатья - https://habrahabr.ru/post/254773/

Слайд 140 Нормальные формы
Используемые термины
Атрибут — свойство некоторой сущности. Часто называется

Нормальные формыИспользуемые термины Атрибут — свойство некоторой сущности. Часто называется полем таблицы.

полем таблицы. Домен атрибута — множество допустимых значений, которые может принимать

атрибут. Кортеж — конечное множество взаимосвязанных допустимых значений атрибутов, которые вместе описывают некоторую сущность (строка таблицы). Отношение — конечное множество кортежей (таблица). Схема отношения — конечное множество атрибутов, определяющих некоторую сущность. Иными словами, это структура таблицы, состоящей из конкретного набора полей.

Слайд 141 Нормальные формы
Проекция — отношение, полученное из заданного путём удаления

Нормальные формыПроекция — отношение, полученное из заданного путём удаления и (или) перестановки

и (или) перестановки некоторых атрибутов. Функциональная зависимость между атрибутами (множествами атрибутов)

X и Y означает, что для любого допустимого набора кортежей в данном отношении: если два кортежа совпадают по значению X, то они совпадают по значению Y. Например, если значение атрибута «Название компании» — Canonical Ltd, то значением атрибута «Штаб-квартира» в таком кортеже всегда будет Millbank Tower, London, United Kingdom. Обозначение: {X} -> {Y}. Нормальная форма — требование, предъявляемое к структуре таблиц в теории реляционных баз данных для устранения из базы избыточных функциональных зависимостей между атрибутами (полями таблиц). Метод нормальных форм (НФ) состоит в сборе информации о объектах решения задачи в рамках одного отношения и последующей декомпозиции этого отношения на несколько взаимосвязанных отношений на основе процедур нормализации отношений. 

Слайд 142 Нормальные формы
Цель нормализации: исключить избыточное дублирование данных, которое

Нормальные формыЦель нормализации: исключить избыточное дублирование данных, которое является причиной аномалий,

является причиной аномалий, возникших при добавлении, редактировании и удалении

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

Слайд 143 Первая нормальная форма
Отношение находится в 1НФ, если все

Первая нормальная формаОтношение находится в 1НФ, если все его атрибуты являются

его атрибуты являются простыми, все используемые домены должны содержать

только скалярные значения. Не должно быть повторений строк в таблице.

Слайд 144 Первая нормальная форма


Первая нормальная форма

Слайд 145 Вторая нормальная форма
Отношение находится во 2НФ, если оно

Вторая нормальная формаОтношение находится во 2НФ, если оно находится в 1НФ

находится в 1НФ и каждый не ключевой атрибут неприводимо

зависит от Первичного Ключа(ПК). Неприводимость означает, что в составе потенциального ключа отсутствует меньшее подмножество атрибутов, от которого можно также вывести данную функциональную зависимость.

Слайд 146 Вторая нормальная форма
Таблица находится в первой нормальной форме,

Вторая нормальная формаТаблица находится в первой нормальной форме, но не во

но не во второй. Цену машины зависит от модели

и фирмы. Скидка зависят от фирмы, то есть зависимость от первичного ключа неполная. Исправляется это путем декомпозиции на два отношения, в которых не ключевые атрибуты зависят от ПК.

Слайд 147 Вторая нормальная форма

Вторая нормальная форма

Слайд 148 Третья нормальная форма
Отношение находится в 3НФ, когда находится

Третья нормальная формаОтношение находится в 3НФ, когда находится во 2НФ и

во 2НФ и каждый не ключевой атрибут нетранзитивно зависит

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

Слайд 149 Третья нормальная форма

Третья нормальная форма

Слайд 150 Третья нормальная форма
Таблица находится во 2НФ, но не

Третья нормальная формаТаблица находится во 2НФ, но не в 3НФ. В

в 3НФ. В отношении существуют следующие функциональные зависимости: Модель →

Магазин, Магазин → Телефон, Модель → Телефон. Зависимость Модель → Телефон является транзитивной, следовательно, отношение не находится в 3НФ.

Слайд 151 Третья нормальная форма

Третья нормальная форма

Слайд 152 Нормальная форма Бойса-Кодда (НФБК) (частная форма третьей нормальной

Нормальная форма Бойса-Кодда (НФБК) (частная форма третьей нормальной формы)Определение 3НФ не

формы)
Определение 3НФ не совсем подходит для следующих отношений: 1) отношение

имеет две или более потенциальных ключа; 2) два и более потенциальных ключа являются составными; 3) они пересекаются, т.е. имеют хотя бы один атрибут. Для отношений, имеющих один потенциальный ключ (первичный), НФБК является 3НФ. Отношение находится в НФБК, когда каждая нетривиальная и неприводимая слева функциональная зависимость обладает потенциальным ключом в качестве детерминанта.

Слайд 153 BCNF
возможны следующие составные первичные ключи: {Номер стоянки, Время

BCNFвозможны следующие составные первичные ключи: {Номер стоянки, Время начала}, {Номер стоянки,

начала}, {Номер стоянки, Время окончания}, {Тариф, Время начала}, {Тариф,

Время окончания}

Слайд 154 BCNF
Отношение находится в 3НФ. Требования второй нормальной формы

BCNFОтношение находится в 3НФ. Требования второй нормальной формы выполняются, так как

выполняются, так как все атрибуты входят в какой-то из

потенциальных ключей, а неключевых атрибутов в отношении нет. Также нет и транзитивных зависимостей, что соответствует требованиям третьей нормальной формы. Тем не менее, существует функциональная зависимость Тариф → Номер стоянки, в которой левая часть (детерминант) не является потенциальным ключом отношения, то есть отношение не находится в нормальной форме Бойса — Кодда. Недостатком данной структуры является то, что, например, по ошибке можно приписать тариф «Бережливый» к бронированию второй стоянки, хотя он может относиться только к первой стоянки.

Слайд 156 Домашнее задание
1. Описать вашу БД для курсовой, как

Домашнее задание1. Описать вашу БД для курсовой, как ее можно применять,

ее можно применять, какие задачи она должна выполнять.
2. Выделить

Атрибуты, Сущности их связи. Построить логическую E-R диаграмму.
3. Построить физическую E-R диаграмму для вашей базы данных.
4. Привести вашу схему к нормальной форме Бойса - Кодда
5. Написать DLL скрипты для генерации ваших таблиц. В них должны быть различные ограничения, первичные ключи, внешние ключи. Также привести примеры с ALTER TABLE.

  • Имя файла: bazy-dannyh.pptx
  • Количество просмотров: 89
  • Количество скачиваний: 0