Skip to content
Open
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
47 changes: 26 additions & 21 deletions task.sql
Original file line number Diff line number Diff line change
@@ -1,33 +1,38 @@
-- Create database and tables

DROP DATABASE IF EXISTS ShopDB;
CREATE DATABASE ShopDB;
USE ShopDB;

CREATE TABLE Countries (
ID INT,
Name VARCHAR(50),
PRIMARY KEY (ID)
ID INT AUTO_INCREMENT PRIMARY KEY,
Name VARCHAR(50)
);

CREATE TABLE ProductInventory (
ID INT,
ProductName VARCHAR(50),
WarehouseAmount INT,
CREATE TABLE Warehouse (
ID INT AUTO_INCREMENT PRIMARY KEY,
WarehouseName VARCHAR(50),
WarehouseAddress VARCHAR(50),
WarehouseAddress VARCHAR(50),
CountryID INT,
FOREIGN KEY (CountryID) REFERENCES Countries(ID) ON DELETE NO ACTION,
PRIMARY KEY (ID)
FOREIGN KEY (CountryID) REFERENCES Countries(ID)
);

CREATE TABLE Products (
ID INT AUTO_INCREMENT PRIMARY KEY,
ProductName VARCHAR(50)
);

CREATE TABLE ProductInventory (
ID INT AUTO_INCREMENT PRIMARY KEY,
ProductID INT,
WarehouseAmount INT,
WarehouseID INT,
FOREIGN KEY (ProductID) REFERENCES Products(ID),
FOREIGN KEY (WarehouseID) REFERENCES Warehouse(ID)
);

-- Populate test data
INSERT INTO Countries (Name) VALUES ('Country1');
INSERT INTO Warehouse (WarehouseName, CountryID) VALUES ('Warehouse-1', 1), ('Warehouse-2', 1);
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This INSERT statement is missing the WarehouseAddress. The task description indicates that the original data included a warehouse address. To meet the requirement of populating the 'same test data', you should include a value for the WarehouseAddress column for each warehouse you're inserting.

INSERT INTO Products (ProductName) VALUES ('AwesomeProduct');

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);
INSERT INTO ProductInventory (ProductID, WarehouseAmount, WarehouseID)
VALUES (1, 10, 1), (1, 20, 2);