Understanding One-to-Many Relationship Between Orders and OrderDetails
Orders Table:

OrderDetails Table:

Query Explanation:
● There is a One-to-Many relationship between Orders and OrderDetails – one order can have multiple order detail entries.
● The OrderID in the OrderDetails table acts as a foreign key, referencing the OrderID in the Orders table.
● This follows proper normalization practices (typically 2NF), where details like quantity and unit price are separated from the order header.
● The INNER JOIN is used to combine rows from both tables where the OrderID matches, returning complete details of each product in the order.
SQL Query:
-- Creating Orders table
CREATE TABLE Orders (
    OrderID INT PRIMARY KEY,
    CustomerID INT,
    OrderDate DATE
);
-- Creating OrderDetails table with foreign key referencing Orders
CREATE TABLE OrderDetails (
    OrderDetailID INT PRIMARY KEY,
    OrderID INT,  -- Foreign key to establish One-to-Many relationship
    ProductID INT,
    Quantity INT,
    UnitPrice DECIMAL(10,2),
    FOREIGN KEY (OrderID) REFERENCES Orders(OrderID)
);
-- Joining Orders and OrderDetails to fetch complete order info
SELECT 
    Orders.OrderID,
    Orders.OrderDate,
    OrderDetails.ProductID,
    OrderDetails.Quantity,
    OrderDetails.UnitPrice
FROM 
    Orders
INNER JOIN 
    OrderDetails ON Orders.OrderID = OrderDetails.OrderID;
Output:

Trainings :
UI UX Design Training in Indore | Python + DSA Training in Indore | DevOps Training in Indore | Data Analytics Training in Indore | Data Science Training in Indore | Full Stack Development Training in Indore | Web Development Training in Indore | Python and Django Training in Indore |Free Courses and Resource :
Verbal Aptitude | Matplotlib Tutorials | Examples | Interview Questions | Pandas Tutorials | Projects | Interview Questions | OpenCV Tutorials | Projects | Interview Questions | ExpressJS Tutorials | Projects | Interview Questions | Dart | Python Data Structures and Algorithms | Rust Tutorials | Projects | Interview Questions | Aptitude Tests | HackerRank Python | Django | MongoDB Tutorials | Examples | Interview Questions | NumPy Practice Questions | Python Tutorials by CodersDaily | Golang Tutorials | Projects | Interview Questions | React.js Tutorials | Verbal Ability Tutorial | MS Sql Server Tutorials | Examples | Interview Questions | Power BI Tutorials | Projects | Interview Questions | Example Dashboards | Numpy Tutorials | Projects | Interview Questions | Django REST Framework Tutorial | HackerRank C++ Solutions | Pandas Practice Questions | Tensor Flow | Python Practice Questions | C++ Tutorials | Quantitative Ability Tutorial | Google Sheets Mastery: From Basics to Dashboards | Langchain Tutorials | Javascript | Node.js Tutorials | HackerRank SQL Solutions | HackerRank DSA Solutions | Verbal Aptitude 2 | HackerRank Java Solutions | HTML Tutorial | TCS NQT Mock Test Series | Reasoning Ability Tutorial | CodeChef Python Solutions | HackerRank C Program Solutions | Leetcode Python Solutions | SQL Practice Question | Matplotlib Practice Questions |Interview Questions :
Pandas Tutorials | Projects | Interview Questions | ExpressJS Tutorials | Projects | Interview Questions | Django | Python Tutorials by CodersDaily | Golang Tutorials | Projects | Interview Questions | Numpy Tutorials | Projects | Interview Questions | Django REST Framework Tutorial | Matplotlib Practice Questions | Matplotlib Practice Questions | Matplotlib Practice Questions | Matplotlib Practice Questions | Matplotlib Practice Questions | Matplotlib Practice Questions | Matplotlib Practice Questions | Matplotlib Practice Questions | Matplotlib Practice Questions | Matplotlib Practice Questions |Top Colleges in India :
Indian Institute of Technology Bombay | Jaypee University of Engineering and Technology - Guna |