data:image/s3,"s3://crabby-images/976dd/976dd817eef350832dd240a0ed94cf140920171f" alt=""
6. Normalization, Cascades
Normalization helps prevent data redundancy and ensures efficient database organization.
Normalization Rules and Forms
The three primary normalization forms are essential, though additional forms exist.
- If two columns can be stored as one and later split, they should be combined.
Example: Instead of storing
name
andsurname
separately, they can be stored asfullname
and split when needed.
- First Normal Form (1NF): Each table must have a primary key, and all columns should be dependent on it.
- Second Normal Form (2NF): If a column's data can be derived from another column, it should not be stored separately.
Example: A student table should not store the group's average score since it can be calculated dynamically.
Following normalization rules helps avoid anomalies in database design.
ON DELETE & ON UPDATE Actions
These constraints define how related records behave when a referenced record is modified or deleted.
ON DELETE
- CASCADE: Deletes related records when the referenced record is deleted.Example: If an Instagram user is deleted, their posts are also deleted.
- NO ACTION: Prevents deletion if related records exist.
- SET NULL: Sets foreign key values to
NULL
when the referenced record is deleted.
- SET DEFAULT: Resets foreign key values to a default value.
ON UPDATE
- CASCADE: Updates related records when the referenced record changes.
Example: If a user’s ID is updated, all references to that ID are also updated.
- NO ACTION: Prevents updates to referenced records.
SQL Query Writing Order
- SELECT
- FROM
- WHERE
- GROUP BY
- HAVING
- ORDER BY
SQL Query Execution Order
- FROM – Identifies the data source.
- WHERE – Filters records based on conditions.
- GROUP BY – Groups records with similar values.
- HAVING – Filters grouped records.
- SELECT – Chooses columns to display.
- ORDER BY – Sorts the final result.
Reference
The content in this document is based on the original notes provided in Azerbaijani. For further details, you can refer to the original document using the following link:
Original Note - Azerbaijani Version