first commit

This commit is contained in:
Vitalii Litvinchuk
2026-05-04 23:15:09 +03:00
commit 6deed0469a
49 changed files with 5366 additions and 0 deletions
+112
View File
@@ -0,0 +1,112 @@
use Lucky_Shrub;
Основні завдання:
Розробка INSERT, UPDATE та DELETE тригерів.
################################################
############## Умови завдань ###############
################ Завдання 1: ###############
1. Створіть INSERT триггер з назвою ProductSellPriceInsertCheck. Тригер має перевірити,
чи ціна SellPrice продукту менша ніж BuyPrice після того як новий продук було додано у таблицю Products.
Якщо таке станеться, у таблицю Notifications має бути додане сповіщення для відділу продажів.
Відділ продажів має переконатися, що таке значення було введено не помилково.
Сповіщення слід додати у такому форматі: 'Для продукту з id ' + ProductID + 'було внесено значення SellPrice яке менше чи рівне BuyPrice'
2. Перегляньте існуючі тригери
3. Перевіте роботу тригера. Додайте запис у таблицю Products із ціною закупки вищою ніж ціна продажу, на прклад:
P7, Агрополотно, 70, 70, 21;
4. Перевірте наявність запису у таблиці Products 5. Перевірте наявність запису у таблиці Notifications
drop trigger ProductSellPriceInsertCheck;
create trigger if not exists ProductSellPriceInsertCheck
after insert on Products
for each row
begin
if new.SellPrice <= new.BuyPrice then
insert into Notifications (Notification, DateTime)
values (concat('Для продукту з id ', new.ProductID, 'було внесено значення SellPrice яке менше чи рівне BuyPrice'), now());
end if;
end;
insert into
Products (
ProductID,
ProductName,
BuyPrice,
SellPrice,
NumberOfItems
)
values (
'P7',
'Агрополотно',
70,
70,
21
);
show triggers like 'Products';
select * from Notifications;
select * from Products;
delete from Products where ProductID = 'P7';
################################################
################ Завдання 2: ###############
1. Створіть UPDATE тригер з назвою ProductSellPriceUpdateCheck. Цей тригер повинен перевіряти
чи продукти не оновлюються з ціною SellPrice, яка менша чи рівна ціні BuyPrice. Якщо це так,
слід додати сповіщення до таблиці Notifications для відділу продажів щоб вони переконалися,
що ціни на продукти не оновлено з некоректними значеннями. Цей тригер надсилає сповіщення у
tаблицю Notifications, яке попереджає відділ продажів про проблему.
Сповіщення має бути додано у такому форматі: ProductID + 'було оновлено зі значенням SellPrice = ' + SellPrice + 'яке менше чи рівне значення BuyPrice'
2. Перегляньте тригери
3. Перевірте роботу тригера. Наприклад, змініть значення SellPrice на 65 для запису з ID продукту P6 таблиці Products
4. Перевірте наявність запису у таблиці Products
5. Перевіряємо наявність запису у таблиці Notifications
drop trigger if exists ProductSellPriceUpdateCheck;
create trigger if not exists ProductSellPriceUpdateCheck
before update on Products
for each row
begin
if new.SellPrice <= new.BuyPrice then
insert into Notifications (Notification, DateTime)
values (concat(new.ProductID, 'було оновлено зі значенням SellPrice = ', new.SellPrice, 'яке менше чи рівне значення BuyPrice'), now());
end if;
end;
update Products set SellPrice = 60 where ProductID = 'P1';
select * from Products where ProductID = 'P1';
select * from Notifications;
################################################
################ Завдання 3: ###############
1. Створіть тригер DELETE з назвою NotifyProductDelete. Цей тригер повинен додати сповіщення
до таблиці Notifications для відділу продажів після того, як продукт було видалено з таблиція Products.
Сповіщення повинно бути у такому форматі: 'Продукт з id' + ProductID + 'було видалено'
2. Перегляньте тригери
3. Перевірте роботу тригра. Наприклад, видаліть один запис із таблицю Products з ID продукту P7
4. Перевірте наявність запису у таблиці Products
5. Перевірте наявність запису у таблиці Notifications
drop trigger NotifyProductDelete;
create trigger if not exists NotifyProductDelete
after delete on Products
for each row
begin
insert into Notifications (Notification, DateTime)
values (concat('Продукт з id ', old.ProductID, 'було видалено'), now());
end;
show triggers like 'Products';
delete from Products where ProductID = 'P1';
select * from Products;
select * from Notifications;