diff --git a/task.sql b/task.sql index cc65344..326e45a 100644 --- a/task.sql +++ b/task.sql @@ -1,5 +1,5 @@ -- Create database and tables - +DROP DATABASE IF EXISTS ShopDB; CREATE DATABASE ShopDB; USE ShopDB; @@ -9,14 +9,28 @@ CREATE TABLE Countries ( PRIMARY KEY (ID) ); +CREATE TABLE Warehouses ( + ID INT AUTO_INCREMENT NOT NULL, + Name VARCHAR(50), + Address VARCHAR(50), + CountryID INT, + FOREIGN KEY (CountryID) REFERENCES Countries(ID) ON DELETE CASCADE, + PRIMARY KEY (ID) +); + +CREATE TABLE Products ( + ID INT AUTO_INCREMENT NOT NULL, + Name VARCHAR(50), + PRIMARY KEY (ID) +); + CREATE TABLE ProductInventory ( - ID INT, - ProductName VARCHAR(50), + ID INT AUTO_INCREMENT NOT NULL, + ProductID INT, WarehouseAmount INT, - WarehouseName VARCHAR(50), - WarehouseAddress VARCHAR(50), - CountryID INT, - FOREIGN KEY (CountryID) REFERENCES Countries(ID) ON DELETE NO ACTION, + WarehouseID INT, + FOREIGN KEY (WarehouseID) REFERENCES Warehouses(ID) ON DELETE CASCADE, + FOREIGN KEY (ProductID) REFERENCES Products(ID) ON DELETE CASCADE, PRIMARY KEY (ID) ); @@ -27,7 +41,15 @@ INSERT INTO Countries (ID,Name) INSERT INTO Countries (ID,Name) VALUES (2, 'Country2'); -INSERT INTO ProductInventory (ID,ProductName,WarehouseAmount,WarehouseName,WarehouseAddress,CountryID) - VALUES (1, 'AwersomeProduct', 2, 'Warehouse-1', 'City-1, Street-1',1); -INSERT INTO ProductInventory (ID,ProductName,WarehouseAmount,WarehouseName,WarehouseAddress,CountryID) - VALUES (2, 'AwersomeProduct', 5, 'Warehouse-2', 'City-2, Street-2',2); +INSERT INTO Warehouses (ID,Name,Address,CountryID) + VALUES (1, 'Warehouse-1', 'City-1, Street-1',1); +INSERT INTO Warehouses (ID,Name,Address,CountryID) + VALUES (2, 'Warehouse-2', 'City-2, Street-2',2); + +INSERT INTO Products (ID,Name) + VALUES (1, 'AwersomeProduct'); + +INSERT INTO ProductInventory (ID,ProductID,WarehouseAmount,WarehouseID) + VALUES (1, 1, 2, 1); +INSERT INTO ProductInventory (ID,ProductID,WarehouseAmount,WarehouseID) + VALUES (2, 1, 5, 2);