Functional Dependency in DBMS
Video Tutorial
Overview
Functional Dependency is the relationship between attributes(characteristics) of a table related to each other. The functional dependency of A on B is represented by A → B, where A and B are the attributes of the relation.
Before reading this article, you should have an understanding of the following DBMS topics:
Scope of the Article
This article discusses
- Functional Dependency
- Their representation
- Types
- Armstrong axioms and
- Advantages of Functional Dependency.
This article does not discuss any details about the normalization and other aspects of databases. Examples are provided wherever necessary but creating a real database and querying is out of the scope of this article.
What is Functional Dependency in DBMS?
Relational database is a collection of data stored in rows and columns. Columns represent the characteristic of data while each row in a table represents a set of related data, and every row in the table has the same structure. The row is sometimes referred to as a tuple in DBMS.
Have a look at the Employee table below. It contains attributes as column values, namely
- Employee_Id
- Employee_Name
- Employee_Department
- Salary
Employee Table
Employee_Id | Employee_Name | Employee_Department | Salary |
---|---|---|---|
1 | Ryan | Mechanical | $5000 |
2 | Justin | Biotechnology | $5000 |
3 | Andrew | Computer Science | $8000 |
4 | Felix | Human Resource | $10000 |
Now that we are clear with the jargon related to functional dependency, let's discuss what functional dependency is.
- Functional Dependency in DBMS, as the name suggests it is the relationship between attributes(characteristics) of a table related to each other.
- A relation consisting of functional dependencies always follows a set of rules called RAT rules. They are proposed by William Armstrong in 1974.
- It helps in maintaining the quality of data in the database, and the core concepts behind database normalization are based on functional dependencies.
How to Denote a Functional Dependency in DBMS?
A functional dependency is denoted by an arrow “→”. The functional dependency of A on B is represented by A → B.
Consider a relation with four attributes A, B, C and D,
R (ABCD)
- A → BCD
- B → CD
- For the first functional dependency A → BCD, attributes B, C and D are functionally dependent on attribute A.
- Function dependency B → CD has two attributes C and D functionally depending upon attribute B.
Sometimes everything on the left side of functional dependency is also referred to as determinant set, while everything on the right side is referred to as depending attributes.
- Functional dependency can also be represented diagrammatically like this,
- Pointing arrows determines the depending attribute and the origin of the arrow determines the determinant set.
Types of Functional Dependencies in DBMS
- Trivial functional dependency
- Non-Trivial functional dependency
- Multivalued functional dependency
- Transitive functional dependency
Trivial Functional Dependency in DBMS
- In Trivial functional dependency, a dependent is always a subset of the determinant. In other words, a functional dependency is called trivial if the attributes on the right side are the subset of the attributes on the left side of the functional dependency.
- X → Y is called a trivial functional dependency if Y is the subset of X.
- For example, consider the Employee table below.
Employee_Id | Name | Age |
---|---|---|
1 | Zayn | 24 |
2 | Phobe | 34 |
3 | Hikki | 26 |
4 | David | 29 |
- Here, { Employee_Id, Name } → { Name } is a Trivial functional dependency, since the dependent Name is the subset of determinant { Employee_Id, Name }.
- { Employee_Id } → { Employee_Id }, { Name } → { Name } and { Age } → { Age } are also Trivial.
Non-Trivial Functional Dependency in DBMS
- It is the opposite of Trivial functional dependency. Formally speaking, in Non-Trivial functional dependency, dependent if not a subset of the determinant.
- X → Y is called a Non-trivial functional dependency if Y is not a subset of X. So, a functional dependency X → Y where X is a set of attributes and Y is also a set of the attribute but not a subset of X, then it is called Non-trivial functional dependency.
- For example, consider the Employee table below.
Employee_Id | Name | Age |
---|---|---|
1 | Zayn | 24 |
2 | Phobe | 34 |
3 | Hikki | 26 |
4 | David | 29 |
-
Here, { Employee_Id } → { Name } is a non-trivial functional dependency because Name(dependent) is not a subset of Employee_Id(determinant).
-
Similarly, { Employee_Id, Name } → { Age } is also a non-trivial functional dependency.
Multivalued Functional Dependency in DBMS
- In Multivalued functional dependency, attributes in the dependent set are not dependent on each other.
- For example, X → { Y, Z }, if there exists is no functional dependency between Y and Z, then it is called as Multivalued functional dependency.
- For example, consider the Employee table below.
Employee_Id | Name | Age |
---|---|---|
1 | Zayn | 24 |
2 | Phobe | 34 |
3 | Hikki | 26 |
4 | David | 29 |
4 | Phobe | 24 |
- Here, { Employee_Id } → { Name, Age } is a Multivalued functional dependency, since the dependent attributes Name, Age are not functionally dependent(i.e. Name → Age or Age → Name doesn’t exist !).
Transitive Functional Dependency in DBMS
- Consider two functional dependencies A → B and B → C then according to the transitivity axiom A → C must also exist. This is called a transitive functional dependency.
- In other words, dependent is indirectly dependent on determinant in Transitive functional dependency.
- For example, consider the Employee table below.
Employee_Id | Name | Department | Street Number |
---|---|---|---|
1 | Zayn | CD | 11 |
2 | Phobe | AB | 24 |
3 | Hikki | CD | 11 |
4 | David | PQ | 71 |
5 | Phobe | LM | 21 |
- Here, { Employee_Id → Department } and { Department → Street Number } holds true. Hence, according to the axiom of transitivity, { Employee_Id → Street Number } is a valid functional dependency.
Armstrong’s Axioms/Properties of Functional Dependency in DBMS
William Armstrong in 1974 suggested a few rules related to functional dependency. They are called RAT rules.
-
Reflexivity: If A is a set of attributes and B is a subset of A, then the functional dependency A → B holds true.
- For example, { Employee_Id, Name } → Name is valid.
-
Augmentation: If a functional dependency A → B holds true, then appending any number of the attribute to both sides of dependency doesn't affect the dependency. It remains true.
- For example, X → Y holds true then, ZX → ZY also holds true.
- For example, if { Employee_Id, Name } → { Name } holds true then, { Employee_Id, Name, Age } → { Name, Age }
-
Transitivity: If two functional dependencies X → Y and Y → Z hold true, then X → Z also holds true by the rule of Transitivity.
- For example, if { Employee_Id } → { Name } holds true and { Name } → { Department } holds true, then { Employee_Id } → { Department } also holds true.
Advantages of Functional Dependency in DBMS
Let's discuss some of the advantages of Functional dependency,
- It is used to maintain the quality of data in the database.
- It expresses the facts about the database design.
- It helps in clearly defining the meanings and constraints of databases.
- It helps to identify bad designs.
- Functional Dependency removes data redundancy where the same values should not be repeated at multiple locations in the same database table.
- The process of Normalization starts with identifying the candidate keys in the relation. Without functional dependency, it's impossible to find candidate keys and normalize the database.
Conclusion
- Functional dependency defines how the attributes of a relation are related to each other. It helps in maintaining the quality of data in the database. It is denoted by an arrow “→”.
- The functional dependency of A on B is represented by A → B. William Armstrong in 1974 suggested a few axioms or rules related to functional dependency. They are
- Rule of Reflexivity
- Rule of Augmentation
- Rule of Transitivity
- There are four types of functional dependency in DBMS - Trivial, Non-Trivial, Multivalued and Transitive functional dependency.
- Functional dependencies have many advantages, keeping the database design clean, defining the meaning and constraints of the databases, and removing data redundancy are a few of them.