Hi I need a little help with finding candidate key with FD:
given relation : R{x,y,z,s,t,u,w}
FD: {s->x , t->y , x->y ,xy->tuz}
is the candidate key {s,w} ?
Related
Here I did 2 questions about functional relations and normal forms and i have some follow-up questions, things I couldn't find answers for.
1. On the relation scheme R(A, B, C, D, E, F) on which following
functional dependencies are being applied:
F = {ABC →D, CE→B, E→C, BF→AC, E→F, F→E}.
• Find (AB)+, (CD)+,(EF)+
• Find all candidate keys.
• Find all function dependencies which cause this relation not to be at BCNF.
(AB)+=AB | (CD)+=CD | (EF)+=EFCBAD
Find all candidate keys
(AB)+=AB | (BF)+=BFECAD
(AC)+=AC | (CE)+=CEBFAD
(AE)+=AECFBD | (CF)+=CFEBAD
(AF)+=AFECBD | (EF)+=EFCBAD
(BC)+=BC | **(E)+=EFCBAD**
(BE)+=BECFAD | **(F)+=FECBAD**
Candidate keys are: E and F
Prime attributes are: E and F
Non-prime attributes are: A, B, C, D
Other Keys that functionally determines relation scheme R are not
candidate keys because they don’t fulfill "minimality" rule!
2nd
2. On the relation scheme R = (A, B, C, D, E, F G, H) on which following
functional dependencies are being applied:
F= {A →E, GH → C, DB → H, BG → A, C → D, G → H, H → B, AE → G}
• Find (A)+ and (DBG)+
• Does G →B applies from fd F
• Find all candidate keys.
• In which normal form is following relations scheme?
(AB)+=AB| (CD)+=CD | (EF)+=EFCBAD
Find all candidate keys:
**(A)+=AEGHBCD** | (B)+=B | (C)+=CD | (D)+=D | (E)+=E | (F)+=F | **(G)+=GHBCDAE** |
(H)+=HB
Candidate keys are: A and G
Other Keys that functionally determines relation scheme R are not
candidate keys because they don’t fulfil minimality rule!
Prime elements are: A and G
Non prime elements are: B, C, D, E, H
1NF – yes
2NF – yes, because there are no partial key dependencies
3NF – no, because ABC ->D (functional dependency between 2 non-prime elements).
BCNF – no, because it is not in 3NF
QUESTIONS:
1) Am I right with all of these that I wrote?
2) At 1st question, there are a lot of keys that are made by 2 elements, but they are not candidate keys, because the "minimal" rule is not applying on them. Am I right with this?
3) What if the part of the key is non-prime and part is prime element and that key functionally determines some other non-prime element. Is that relation at 3rd Normal form?
4) What if candidate part of the key (prime element) functionally determines another prime element, is that relation at 2nd Normal form?
5) In case there are a lot of keys that has "minimization" characteristics and they are candidate keys, do they all apply as candidate keys (for example 10 candidate keys)?
6) At 2nd question here, the F element is not being used in any functional dependency, but it is part of relation scheme. Do I left element F out, or element F must be part of the candidate key (also prime attribute/element)?
I have a relation A,B,C,D,E with functional dependencies
1) A->BC
2) CD->E
3) B->D
4) E->A
Using 1 gives A,D,E and then using 4 will make it D,E
Using 2 gives A,B,C,D and then using 3 gives A,B,C and using 1 gives A
Using 2 gives A,B,C,D and using 1 gives A,D
Using 4 gives B,C,D,E and using 2 gives B,C,D and using 3 gives B,C
Using 3 gives A,B,C,E and using 1 gives A,E and using 4 gives E
So I would have 5 super keys? (A, E, AD, BC, DE). And from my super keys I would pick the unique ones.
Since I can get A from E, I can remove A and AD(since DE is the same) and since I can get BC from A I can remove that so I am left with
E, DE
Would that be my super key? Or would it just be E?
By definition, a candidate key K of a relation is a set of attributes that determines all the others and such that we cannot remove any attribute from it without losing this property.
To find all the keys of the relation, if you do not follow a formal algorithm, then you could start by checking from each determinant of the FDs and see if this is a (super or candidate) key, by calculating its closure. For instance, starting from A, you can find:
A+ = A
= ABC (by using 1)
= ABCD (by using 3)
= ABCDE (by using 2)
So, A determines all the attributes and for this reason is a candidate key (and not a strict superkey, since you cannot remove any attribute from it!)
Calculating the closures of the other determinants, you can find that:
CD+ = ABCDE (candidate key, since C+ and D+ do not contain all the attributes)
B+ = BD (not a key)
E+ = ABCDE (candidate key)
Now you have three candidate keys, A, E, and CD. And since B determines only D, we could try to add something to it to see if it can be part of a key. We do not add A, or E, since they are already keys, and we do not add D since it is already determinated by B (so that having it will produce surely a superkey). So we try C:
BC+ = ABCDE (candidate key, since B+ and C+ do not contain all the attributes)
So, finally, we can say that the relation has four (and only four) candidate keys:
A
BC
CD
E
The superkeys of one example look as follows: ABCF CDF ACDF BCDF ABCDF ABCEF CDEF ACDEF BCDEF ABCDEF
The output that contains all possible candidate keys: ABCF CDF
In the example above, how do you get the possible candidate keys output from that set of superkeys? I don't understand how to get that result, please help.
A very simple algorithm to find all the candidate keys from the set of all the possible keys and superkeys is the following (in pseudocode):
Input: A set SK of all the (candidate keys and) superkeys of a relation R
Output: The set K of all the candidate keys of SK
Let K = SK
For each k in K do:
Remove all the keys sk in K such that k is a proper subset of sk
At the end of the loop, the set K will contain the result expected.
I'm studying for my database exam and I'm not sure about one question which goes as follow:
Given the relation R={A, B, C, D, E, F, G, H, I} and the set of functional dependencies
F = { AB -> C,
A -> DE,
C -> AB,
B -> FGH,
D -> IJ,
D -> CBE
}
Under what (normal) form is this relation?
First, I know I have to find all candidate keys. Looking at the right, I see that every attribute of R appears on the right hand-side, so it is not trivial that any single attribute of R is a candidate key. So looking at the left hand-size, only A, B, C, D appear, so one or some of these attributes must appear in the candidate keys.
So using A, C and D works (details skipped), but using B alone doesn't. Considering using two-attribute ket is useless since any key that does not contain A, C or D won't "bring us back" to R. Exemple, BE allows us to find B, E, F, G, H, but then we can't proceed further, so not all attributes of R are found.
Also, using any combination with A, C, or D in it is useless since it contains a subset (a single attribute) which is part of a candidate key (a single attribute). Example, AB can be reduced to A, and then all attributes of R can be found.
What bugs me is AB -> C and C -> AB, which is a circular dependency. I thought of two possibilities:
C is the primary key and we can use it to find A and B (C -> AB);
AB can be reduced to A (as said above) and with it we can find C.
But it is very easy to see that AB must be unique and C must also be unique.
Let's only use AB -> C. We can have the following associations:
11 -> 1 (A = 1, B = 1, C = 1)
12 -> 1
But then, if we reinsert the rule C -> AB, we find:
1 -> 11
1 -> 12
which can't hold.
So C has to be unique.
Same thing if we only consider C -> AB, and then reinsert the rule AB -> C.
I'm starting to think that this is a trick and that the real primary key of this relation is ABC to ensure uniqueness of the combinations of AB and C. We would then have the following rules:
F'={
ABC -> DEFGH
D -> IJ
D -> CBE
}
Is this right? What about the other circular dependency, i.e. C -> D (first rule), D -> C (third rule), and C -> D (going back to first rule)? Do I simply not care about it?
If I don't care about it (and assuming the primary key is ABC), then it seems obvious that this table is not in 3NF since ABC determines D (which is a non prime attribute here), and D determines IJ, two non prime attributes. But it seems to be in 2NF because no non prime attribute (D, E, F, G, H, I, J) can be obtain using a subset of attributes of the candidate keys (ABC here).
Of course, I could consider the primary key to be A, C or D and split AB -> C and C -> AB in two separate relations, but I don't think joining those two tables will always respect the rules AB -> C and C -> AB. For example, if someone inserts a new row in one of the table, then the join could introduce an invalid row.
I am thinking too much? Am I going in the wrong direction?
Thanks for your help :)
AB -> C
A -> DE
C -> AB
B -> FGH
D -> IJ
D -> CBE
I will assume that the FDs in your relation are known to be exactly those in the the transitive closure of F. (What were you actually told about F vis a vis your relation?)
{} only determines trivially.
{A} determines DE, which determines IJCB, which determines FGH. CK.
{B} determines FGH. Not CK.
{C} determines AB. CK.
{D} determines IJCBE. CK.
Other singleton sets just determine trivially.
Proper supersets of A, C and D are not CKs.
Other proper supersets are of B,E,F,G,H,I,J, which cannot determine A, C or D. Not CKs.
That accounts for all subsets of attributes.
So the CKs are {A},{B} and {D}.
What bugs me is AB -> C and C -> AB, which is a circular dependency.
Why should this bug you? Just follow the rules you were given. Review the definition of CK and how to determine the CKs from FDs. Eschew non-technical terms.
the real primary key of this relation
"Primary key" is not a useful notion in normalization. (I can't make much sense of what follows.)
this table is not in 3NF since
I don't see any definition of 3NF being used in your reasoning. You seem to use a definition of BCNF, but not properly.
assuming the primary key is ABC
the candidate keys (ABC here)
Make up your mind. Is there one candidate key {A,B,C} or three candidate keys {A}, {B} and {C}? This is two different situations.
it seems to be in 2NF because no non prime attribute [...] can be obtain using a subset of attributes of the candidate keys
You mean no non-prime attribute is functionally dependent on a proper subset of attributes of any candidate key. You misquoted, then misused what you quoted as if it meant what you should have quoted.
Review the definitions of the normal forms and the definitions they depend on.
I have a relation looks like:
R = (X,Y,C,D)
and functional dependencies:
FD = {XY -> CD, YC -> D, D -> X}
I found out that the candidate keys are XY, YC, YD.
In this case, I have 3 candidate keys... so how do I use them when I decompose the relation into BCNF? I've never done decomposition of the relation with more than one key...
Thanks.
Relation 1: (Y,C,D)
Relation 2: (D,X)
#KeyM
1.Find out the FD that violates BCNF
In this case its D->X
2.Decompose into two relations R1,R2
R1(D,X) R2(D,rest)
3. Repeat 1,2 until all of the relations are in BCNF
Using this our solution is R1(Y,C,D) , R2(D,X)