From daf48ac6970f63548da384ac9936d31c5ce1ea25 Mon Sep 17 00:00:00 2001 From: elfredburger Date: Thu, 25 Jul 2024 14:40:01 +0200 Subject: [PATCH] Solution --- task.sql | 51 +++++++++++++++++++++++++++++++++------------------ 1 file changed, 33 insertions(+), 18 deletions(-) diff --git a/task.sql b/task.sql index cc65344..19bc044 100644 --- a/task.sql +++ b/task.sql @@ -4,30 +4,45 @@ CREATE DATABASE ShopDB; USE ShopDB; CREATE TABLE Countries ( - ID INT, + ID INT AUTO_INCREMENT, Name VARCHAR(50), PRIMARY KEY (ID) ); -CREATE TABLE ProductInventory ( - ID INT, - ProductName VARCHAR(50), - WarehouseAmount INT, + +CREATE TABLE Warehouses ( + ID INT AUTO_INCREMENT, WarehouseName VARCHAR(50), - WarehouseAddress VARCHAR(50), + WarehouseAddress VARCHAR(50), CountryID INT, - FOREIGN KEY (CountryID) REFERENCES Countries(ID) ON DELETE NO ACTION, + FOREIGN KEY (CountryID) REFERENCES Countries(ID) ON DELETE NO ACTION, + PRIMARY KEY (ID) +); + +CREATE TABLE Products ( + ID INT AUTO_INCREMENT, + ProductName VARCHAR(50), PRIMARY KEY (ID) ); --- Populate test data - -INSERT INTO Countries (ID,Name) - VALUES (1, 'Country1'); -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); +CREATE TABLE ProductInventory ( + ID INT AUTO_INCREMENT, + ProductID INT, + WarehouseAmount INT, + WarehouseID INT, + FOREIGN KEY (WarehouseID) REFERENCES Warehouses(ID) ON DELETE NO ACTION, + FOREIGN KEY (ProductID) REFERENCES Products(ID) ON DELETE NO ACTION, + PRIMARY KEY (ID) +); + +INSERT INTO Countries (Name) + VALUES ('Country1'), ('Country2'); + + +INSERT INTO Products (ProductName) + VALUES( 'AwersomeProduct' ), ( 'AwersomeProduct' ); +INSERT INTO Warehouses (WarehouseName, WarehouseAddress, CountryID) + VALUES ('Warehouse-1', 'City-1, Street-1',1), ('Warehouse-2', 'City-2, Street-2',2); + +INSERT INTO ProductInventory (ProductID,WarehouseAmount,WarehouseID) + VALUES (1, 2, 1) , (2, 5, 2);