0000
Concept of Functional Dependency Preserving
.png)
If F1 ∪ F2 = F then it is functional dependency preserving.
Dependency preserving and lossless or lossy decomposing are independent not related. Both are different concepts.
Another method to check dependency preserving:
.png)
So, we can use any of one but functional dependency closer is lengthy it is better to use F1 ∪ F2 = F
So, F1 ∪ F2 = F, then it is dependency preserving if it is not dependency preserving then F1 ∪ F2 ⊂ F
But F1 ∪ F2 ⊃ F is never possible because F1 and F2 are decomposed from F. So, extra FDs is never possible at F1 or F2 rather some dependency may be lost.
So, Dependency preserving happens when F1 ∪ F2 = F but how to check the equivalent of two sets
A = B (A and B is set)
1. A ⊆ B
2. B ⊆ A
If we prove 1 and 2 then we can say A = B
Now we prove
.png)
.png)
If both cases are true then we can say
.png)
But 1 F1 ∪ F2 ⊆ F is always true even it dependency preserving or not.
So, if we only prove 2 condition i.e. F ⊂ F1 ⋃ F2 then we can say it is dependency preserving or not.
For example:
Let a relation R (ABC)
FDs = {A → B, B → C, A → C}
Decomposition (D) = {AB, BC}
.png)
So, we can say
.png)
Now check F ⊂ F1 ⋃ F2, this means we check all FDs of F are present in the set of FDs (F1 ∪ F2) or not. If present then it is dependency preserving otherwise not.
.png)
F1 ∪ F2 = {A → B, B → C} and also derive A → C from the transitive property. A → B, B → C then A → C. So, all FDs of F present in F1 ∪ F2. It is dependency preserving.
Without the transitive rule, we can do another way we can calculate
.png)
.png)
Example 2:
Let a relation R (ABCD) and FDs = {A → B, B → C, A → C, D → C} and D = {AB, BCD}
From AB how many FDs we can get where AB is on left-hand side A, B, AB, ɸ.
So, here we calculate –
.png)
And take valid FDs which match with AB attribute.
.png)
.png)
.png)
.png)
.png)
.png)
We only take non-trivial FDs not consider trivial FDs like A → A, B → B, AB → A, AB → B, etc.
So, only valid FD here A → B
.png)
BCD
Here we can take
.png)
.png)
.png)
.png)
.png)
.png)
.png)
We can take BD → C but it can derive from B → C augmented both sides with D, BD → CD and by splitting properly we can get BD → C. So, only valid one B → C.
.png)
.png)
Now check F ⊆ F1 ∪ F2 means all FDs of F present in F1 ∪ F2 or not.
A → C, A → D not present at F1 ∪ F2. So, it is not dependency preserving.
.png)
Now, from the above two
.png)
So,
.png)
.png)
.png)
In general,
.png)
.png)
.png)
And
.png)
Here
.png)
.png)
Contributed by
