# Week 1

This session is about understanding the entity relationship model, being able to use that knowledge and implement it building a database schema. With the database schema created, you should be able to create a database and test it using SQL statements.

## Contents

* [Preparation](/course-content/backend/databases/week1/preparation.md)
* [Session Plan](/course-content/backend/databases/week1/session-plan.md) (for mentors)
* [Assignment](/course-content/backend/databases/week1/assignment.md)

## Learning Goals

By the end of this session, you will be able to:

* [ ] Create an entity relationship diagram from a description of data requirements
* [ ] Translate a simple entity relationship diagram into a database schema
* [ ] Use SQL CRUD operations for more complex scenarios (INSERT with Foreign keys, DELETE with filters)
* [ ] Use foreign keys to establish relationships between tables
* [ ] Write SQL queries to retrieve related data using JOIN operations

## Main Topics

* Entity-Relationship Diagrams (ERDs):
  * Introduction to ERDs
  * Components: Entities, Attributes, Relationships (1:1, 1:M, M:M)
* Translating ERDs to Database Schema:
  * Mapping rules for tables, columns, primary keys (PKs), and foreign keys (FKs)
* Working with Related Data:
  * Foreign Keys and Constraints (ON DELETE, ON UPDATE actions)
  * SQL JOIN Operations (INNER JOIN, LEFT JOIN)


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://program.hackyourfuture.dk/course-content/backend/databases/week1.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
