{
  "title": "Relational Schema Normalization and Decomposition",
  "turns": [
    {
      "turn": 1,
      "user": "Image",
      "assistant": "The given image shows the set of functional dependencies $F$ for the relation schema \\$(A, B, C, D, E, G)\\$.\n\n $F=\\left{A\\rightarrow BCD,BC\\rightarrow DE,B\\rightarrow D,D\\rightarrow A\\right}$ \n\nUsing these functional dependencies, we need to do the following:\n\n**a. Compute  $B^{+}$.**\n\n\\$B^+\\$ is the set of all attributes that can be inferred from  $B$.\n\n1.  Start:  $B^{+}=\\left{B\\right}$ \n2.   $B\\rightarrow D$  :  Add  $D$ to $B^+$.  $B^{+}=\\left{B,D\\right}$ \n3.   $D\\rightarrow A$  :  Add  $A$ to $B^+$.  $B^{+}=\\left{B,D,A\\right}$ \n4.   $A\\rightarrow BCD$  :  Add  $B,C,D$ to $B^+$.  $B$ and  $D$ are already there.  Add  $C$ to $B^+$.  $B^{+}=\\left{B,D,A,C\\right}$ \n5.   $BC\\rightarrow DE$ :  Since  $B,C$ are in $B^+$, add  $D,E$ to $B^+$.  $D$ is already there.  Add  $E$ to $B^+$.  $B^{+}=\\left{B,D,A,C,E\\right}$ \n\nTherefore, \\$B^+ = {A, B, C, D, E}\\$.\n\n**b. Prove that  $AG$ is a superkey using Armstrong's axioms.**\n\nA superkey is a set of attributes that can uniquely determine all attributes of the schema. In other words, we must show that \\$(AG)^+ = {A, B, C, D, E, G}\\$.\n\n1.  Start:  $\\left(AG\\right)^{+}=\\left{A,G\\right}$ \n2.   $A\\rightarrow BCD$ :  Add  $B,C,D$ to \\$(AG)^+\\$.  $\\left(AG\\right)^{+}=\\left{A,G,B,C,D\\right}$ \n3.   $B\\rightarrow D$ :  Since  $B$ is in $(AG)^+$,  $D$ is already there.\n4.   $D\\rightarrow A$ :  Since  $D$ is in $(AG)^+$,  $A$ is already there.\n5.   $BC\\rightarrow DE$ :  Since  $B,C$ are in $(AG)^+$, add  $D,E$ to $(AG)^+$.  $D$ is already there.  Add  $E$ to $(AG)^+$.  $\\left(AG\\right)^{+}=\\left{A,G,B,C,D,E\\right}$ \n\n\\$(AG)^+ = {A, B, C, D, E, G}\\$. Since this includes all attributes of the relation schema,  $AG$ is a superkey.\n\n**c. Compute the canonical cover for the set of functional dependencies  $F$, and explain each derivation step.**\n\nThe steps to find the canonical cover are as follows:\n\n**Step 1: Make the RHS of each functional dependency a single attribute.**  Original set of  $F$:  $F=\\left{A\\rightarrow BCD,BC\\rightarrow DE,B\\rightarrow D,D\\rightarrow A\\right}$ \n\n Decompose  $A\\rightarrow BCD$ into  $A\\rightarrow B,A\\rightarrow C,A\\rightarrow D$.  Decompose  $BC\\rightarrow DE$ into  $BC\\rightarrow D,BC\\rightarrow E$.\n\n $F_{1}=\\left{A\\rightarrow B,A\\rightarrow C,A\\rightarrow D,BC\\rightarrow D,BC\\rightarrow E,B\\rightarrow D,D\\rightarrow A\\right}$ \n\n**Step 2: For each  $X\\rightarrow Y$, remove extraneous attributes from  $X$.** We look for functional dependencies that have extraneous attributes. In  $X\\rightarrow Y$, if \\$A\\in X\\$ is extraneous, then \\$Y\\$ should be derivable from \\$F\\_1 - {X \\\\rightarrow Y} \\\\cup {(X - {A}) \\\\rightarrow Y}\\$.\n\n*    $A\\rightarrow B$ :  $A$ has no extraneous attribute.\n*    $A\\rightarrow C$ :  $A$ has no extraneous attribute.\n*    $A\\rightarrow D$ :  $A$ has no extraneous attribute.\n*    $BC\\rightarrow D$ :  Is  $B$ extraneous?  Check whether  $C\\rightarrow D$ can be derived from  $F_{1}$.\n    *    $C^{+}$  (under F1 -  $BC\\rightarrow D$) does not include  $D$. (C cannot derive  $D$)\n    *    If we remove  $C\\rightarrow D$ and compute  $(C)^+$ using  $B\\rightarrow D$,  $D$ is still not included. Therefore,  $B$ is not extraneous.\n*    Is  $C$ extraneous?  Check whether  $B\\rightarrow D$ can be derived from  $F_{1}$.\n    *    $B\\rightarrow D$ is already in  $F_{1}$. Therefore, in  $BC\\rightarrow D$,  $C$ is extraneous.\n    *    Replace  $BC\\rightarrow D$ with  $B\\rightarrow D$.\n    *   **Updated  $F_{1}=\\left{A\\rightarrow B,A\\rightarrow C,A\\rightarrow D,BC\\rightarrow E,B\\rightarrow D,D\\rightarrow A\\right}$ ** (Note:  $B\\rightarrow D$ is now duplicated.)\n*    $BC\\rightarrow E$ :  Is  $B$ extraneous?  Check whether  $C\\rightarrow E$ can be derived from  $F_{1}$.\n    *    $C^{+}$  (under F1 -  $BC\\rightarrow E$) does not include  $E$. (C cannot derive  $E$)\n    *   Therefore,  $B$ is not extraneous.\n*    Is  $C$ extraneous?  Check whether  $B\\rightarrow E$ can be derived from  $F_{1}$.\n    *    $B^{+}$  (under F1 -  $BC\\rightarrow E$) does not include  $E$.\n    *    We have  $B\\rightarrow D$, but there's no  $D\\rightarrow E$  or  $A\\rightarrow E$, so we cannot get  $E$. Therefore,  $C$ is not extraneous.\n    *    $BC\\rightarrow E$ has no extraneous attributes.\n*    $B\\rightarrow D$ :  $B$ has no extraneous attribute.\n*    $D\\rightarrow A$ :  $D$ has no extraneous attribute.\n\n**Step 3: Remove redundant functional dependencies.**  $F_{1}=\\left{A\\rightarrow B,A\\rightarrow C,A\\rightarrow D,BC\\rightarrow E,B\\rightarrow D,D\\rightarrow A\\right}$ \n\n*    $A\\rightarrow D$ :\n    *    Via  $D\\rightarrow A$ and  $A\\rightarrow B$ we get  $D\\rightarrow B$, and via  $B\\rightarrow D$ we get  $D\\rightarrow D$.\n    *    From  $D\\rightarrow A$ we get  $A$, and  $A\\rightarrow D$ is not yet redundant.\n    *   Consider \\$F\\_1 - {A \\\\rightarrow D}\\$.\n        *    $A^{+}$  (under F1 -  $A\\rightarrow D$):\n            *   Start:  $\\left{A\\right}$ \n            *    $A\\rightarrow B$ :  Add  $B$.  $\\left{A,B\\right}$ \n            *    $B\\rightarrow D$ :  Add  $D$.  $\\left{A,B,D\\right}$ \n            *    $D\\rightarrow A$ :  $A$ is already there.\n            *    $BC\\rightarrow E$ :  We have  $B$ but not  $C$, so we cannot get  $E$.\n            *    $A\\rightarrow C$ :  Add  $C$.  $\\left{A,B,C,D\\right}$ \n            *    $BC\\rightarrow E$ :  Since  $B,C$ are present, add  $E$.  $\\left{A,B,C,D,E\\right}$ \n            *   $A^+$ still includes  $D$. Therefore,  $A\\rightarrow D$ is redundant.\n    *   **Updated  $F_{2}=\\left{A\\rightarrow B,A\\rightarrow C,BC\\rightarrow E,B\\rightarrow D,D\\rightarrow A\\right}$ **\n*    $B\\rightarrow D$ :\n    *   Consider \\$F\\_2 - {B \\\\rightarrow D}\\$.\n    *    $B^{+}$  (under F2 -  $B\\rightarrow D$):\n        *   Start:  $\\left{B\\right}$ \n        *    $D\\rightarrow A$ :  Without  $D$, we cannot get  $A$.\n        *    None of  $A\\rightarrow B,A\\rightarrow C,BC\\rightarrow E$, etc., can derive  $D$ from  $B$.\n    *   Therefore,  $B\\rightarrow D$ is not redundant.\n*    $D\\rightarrow A$ :\n    *   Consider \\$F\\_2 - {D \\\\rightarrow A}\\$.\n    *    $D^{+}$  (under F2 -  $D\\rightarrow A$):\n        *   Start:  $\\left{D\\right}$ \n        *   Nothing can derive  $A$ from  $D$.\n    *   Therefore,  $D\\rightarrow A$ is not redundant.\n\nFinal canonical cover  $F_{C}$ :  $F_{C}=\\left{A\\rightarrow B,A\\rightarrow C,B\\rightarrow D,D\\rightarrow A,BC\\rightarrow E\\right}$ \n\n**d. 3NF decomposition of the given schema based on the canonical cover.**\n\nA 3NF decomposition aims to preserve functional dependencies and be lossless. Canonical cover  $F_{C}=\\left{A\\rightarrow B,A\\rightarrow C,B\\rightarrow D,D\\rightarrow A,BC\\rightarrow E\\right}$ \n\nFor each functional dependency  $X\\rightarrow Y$, create a relation schema  $R_{i}=XY$.\n\n1.   $A\\rightarrow B$ :  $R_{1}\\left(A,B\\right)$ \n2.   $A\\rightarrow C$ :  $R_{2}\\left(A,C\\right)$ \n3.   $B\\rightarrow D$ :  $R_{3}\\left(B,D\\right)$ \n4.   $D\\rightarrow A$ :  $R_{4}\\left(D,A\\right)$ \n5.   $BC\\rightarrow E$ :  $R_{5}\\left(B,C,E\\right)$ \n\nNow we need to check whether any of these schemas contains a candidate key. A candidate key of the original schema is  $AG$.  $\\left(AG\\right)^{+}=\\left{A,B,C,D,E,G\\right}$  Based on the canonical cover  $A\\rightarrow B,A\\rightarrow C,B\\rightarrow D,D\\rightarrow A,BC\\rightarrow E$, none of  $R_{1}\\left(A,B\\right)$ ,  $R_{2}\\left(A,C\\right)$ ,  $R_{3}\\left(B,D\\right)$ ,  $R_{4}\\left(D,A\\right)$ ,  $R_{5}\\left(B,C,E\\right)$  contains  $G$.\n\nTherefore, we must add a schema that contains a candidate key. Since the candidate key is  $AG$, \\$R\\_6(A, G)\\$ is added.\n\nThe final 3NF decomposition is:  $R_{1}\\left(A,B\\right)$   $R_{2}\\left(A,C\\right)$   $R_{3}\\left(B,D\\right)$   $R_{4}\\left(D,A\\right)$   $R_{5}\\left(B,C,E\\right)$   $R_{6}\\left(A,G\\right)$  (This is the relation containing a candidate key, so if  $G$ is not included elsewhere in the decomposition, it must be added. In our case,  $G$ does not appear in any functional dependency, so it should be included in this relation.)\n\n**e. BCNF decomposition of the given schema using the original set of functional dependencies  $F$.**\n\nBCNF decomposition is a stronger normal form. BCNF is satisfied only if for every nontrivial functional dependency  $X\\rightarrow A$,  $X$ is a superkey.  $R=\\left(A,B,C,D,E,G\\right)$   $F=\\left{A\\rightarrow BCD,BC\\rightarrow DE,B\\rightarrow D,D\\rightarrow A\\right}$ \n\n1.  \\*\\* $R_{0}\\left(A,B,C,D,E,G\\right)$ \\*\\* start.\n    *    $A\\rightarrow BCD$ :  $A$ is not a superkey ( $A^{+}=\\left{A,B,C,D\\right}$ ). Therefore, violation.\n        *   Decompose this:\n            *    $R_{1}\\left(A,B,C,D\\right)$  (A is a key)\n            *    $R_{2}\\left(A,E,G\\right)$  (remaining attributes)\n        *    $F_{1}$  (FDs of $F$ projected to R1):  $A\\rightarrow BCD,B\\rightarrow D,D\\rightarrow A$ \n        *    $F_{2}$  (FDs of $F$ projected to R2): none (A -\\> E is not in F).\n2.  \\*\\* Consider $R_{1}\\left(A,B,C,D\\right)$ \\*\\*.\n    *    $A\\rightarrow BCD$ : A is a key of R1, so no problem.\n    *    $B\\rightarrow D$ :  $B$ is not a superkey of R1 ( $B^{+}=\\left{B,D\\right}$ ). Violation.\n        *   Decompose this:\n            *    $R_{11}\\left(B,D\\right)$  (B is a key)\n            *    $R_{12}\\left(A,B,C\\right)$  (remaining attributes)\n        *    $F_{11}$  (FDs of $F$ projected to \\$R\\_{11}\\$):  $B\\rightarrow D,D\\rightarrow A$  (Since A is not an attribute of R11, in fact  $D\\rightarrow A$ does not apply to \\$R\\_{11}\\$.)\n        *    $F_{12}$  (FDs of $F$ projected to \\$R\\_{12}\\$):  $A\\rightarrow BC,A\\rightarrow B,A\\rightarrow C$ \n3.  \\*\\* Consider $R_{12}\\left(A,B,C\\right)$ \\*\\*.\n    *    $A\\rightarrow BC$ :  $A$ is a key of \\$R\\_{12}\\$, so no problem.\n    *   No further BCNF violations.\n4.  \\*\\* Consider $R_{2}\\left(A,E,G\\right)$ \\*\\*.\n    *   No BCNF violations.\n\nTherefore, the BCNF decomposition is:  $R_{11}\\left(B,D\\right)$   $R_{12}\\left(A,B,C\\right)$   $R_{2}\\left(A,E,G\\right)$ \n\nNote: BCNF decomposition does not guarantee dependency preservation. In the decomposition above,  $BC\\rightarrow DE$ may not be preserved. The original  $BC\\rightarrow DE$ spans \\$R\\_{12}\\$ and \\$R\\_{11}\\$.  Since  $BC$ is in \\$R\\_{12}\\$ and  $D$ is in \\$R\\_{11}\\$ and  $E$ is in  $R_{2}$,  $BC\\rightarrow DE$ is not directly preserved after the decomposition.\n\n**Final BCNF decomposition:**  $R_{1}\\left(B,D\\right)$   $R_{2}\\left(A,B,C\\right)$   $R_{3}\\left(A,E,G\\right)$  A set of functional dependencies  $F$ is given for the database schema \\$(A, B, C, D, E, G)\\$:  $F=\\left{A\\rightarrow BCD,BC\\rightarrow DE,B\\rightarrow D,D\\rightarrow A\\right}$ \n\nThe answers to each question are as follows.\n\n### a.  Compute  $B^{+}$\n\n\\$B^+\\$ is the set of all attributes that can be derived from attribute  $B$.\n\n1.  Initial:  $B^{+}=\\left{B\\right}$ \n2.   Since  $B\\rightarrow D$ is in  $F$, add  $D$ to $B^+$.  $B^{+}=\\left{B,D\\right}$ \n3.   Since  $D\\rightarrow A$ is in  $F$, add  $A$ to $B^+$.  $B^{+}=\\left{A,B,D\\right}$ \n4.   Since  $A\\rightarrow BCD$ is in  $F$, through  $A$ add  $B,C,D$ to $B^+$.  $B$ and  $D$ are already there, but  $C$ is added.  $B^{+}=\\left{A,B,C,D\\right}$ \n5.   Since  $BC\\rightarrow DE$ is in  $F$ and  $B,C$ are in $B^+$, add  $D,E$ to $B^+$.  $D$ is already there, but  $E$ is added.  $B^{+}=\\left{A,B,C,D,E\\right}$ \n6.  No more attributes can be added.\n\nTherefore, \\$B^+ = {A, B, C, D, E}\\$.\n\n### b. Prove that  $AG$ is a superkey using Armstrong's axioms\n\nTo prove it is a superkey, \\$(AG)^+\\$ must contain all attributes of the relation schema \\${A, B, C, D, E, G}\\$.\n\n1.  **Initial:**  $\\left(AG\\right)^{+}=\\left{A,G\\right}$  (reflexivity:  $AG\\rightarrow AG$ )\n2.   Since  $A\\rightarrow BCD$  (given FD), add  $B,C,D$ to \\$(AG)^+\\$.  $\\left(AG\\right)^{+}=\\left{A,B,C,D,G\\right}$ \n3.   Since  $B\\rightarrow D$  (given FD),  $D$ is already in \\$(AG)^+\\$.\n4.   Since  $D\\rightarrow A$  (given FD),  $A$ is already in \\$(AG)^+\\$.\n5.   Since  $BC\\rightarrow DE$  (given FD) and  $B,C$ are in \\$(AG)^+\\$, add  $D,E$ to \\$(AG)^+\\$.  $D$ is already there, but  $E$ is added.  $\\left(AG\\right)^{+}=\\left{A,B,C,D,E,G\\right}$ \n\n\\$(AG)^+\\$ contains all attributes \\${A, B, C, D, E, G}\\$ of the relation schema. Therefore,  $AG$ is a superkey.\n\n### c. Compute the canonical cover for the set of functional dependencies  $F$ (Canonical Cover)\n\nThe steps to compute the canonical cover are as follows. **Step 1: Decompose every RHS into single attributes.**\n\n*    Decompose  $A\\rightarrow BCD$ into  $A\\rightarrow B,A\\rightarrow C,A\\rightarrow D$.\n*    Decompose  $BC\\rightarrow DE$ into  $BC\\rightarrow D,BC\\rightarrow E$.\n*    $F_{1}=\\left{A\\rightarrow B,A\\rightarrow C,A\\rightarrow D,BC\\rightarrow D,BC\\rightarrow E,B\\rightarrow D,D\\rightarrow A\\right}$ \n\n**Step 2: Remove extraneous attributes from the LHS. For each functional dependency, check whether each attribute on the LHS is extraneous. An attribute is extraneous if the dependency still holds after removing it.**\n\n*    $A\\rightarrow B$ : There is only one attribute on the LHS, so none is extraneous.\n*    $A\\rightarrow C$ : There is only one attribute on the LHS, so none is extraneous.\n*    $A\\rightarrow D$ : There is only one attribute on the LHS, so none is extraneous.\n*    $BC\\rightarrow D$ :\n    *    Check if  $B$ is extraneous: removing  $B$ from  $BC$ gives  $C\\rightarrow D$.  Compute  \\$C^+\\$ under  $F_{1}$.  $C^{+}=\\left{C\\right}$  (cannot derive  $D$ from   $C$). Therefore,  $B$ is not extraneous.\n    *    Check if  $C$ is extraneous: removing  $C$ from  $BC$ gives  $B\\rightarrow D$.  Compute  \\$B^+\\$ under  $F_{1}$.  $B^{+}=\\left{B,D,A,C,E\\right}$ .  Since  $D$ is in  \\$B^+\\$,  $B\\rightarrow D$ holds. Therefore,  $C$ is extraneous in  $BC\\rightarrow D$.\n        *    Replace  $BC\\rightarrow D$ with  $B\\rightarrow D$. ( $B\\rightarrow D$ is already in  $F_{1}$)\n*    $BC\\rightarrow E$ :\n    *    Check if  $B$ is extraneous: removing  $B$ from  $BC$ gives  $C\\rightarrow E$.  Compute  \\$C^+\\$ under  $F_{1}$.  $C^{+}=\\left{C\\right}$ .  Since  $E$ is not in  \\$C^+\\$,  $B$ is not extraneous.\n    *    Check if  $C$ is extraneous: removing  $C$ from  $BC$ gives  $B\\rightarrow E$.  Compute  \\$B^+\\$ under  $F_{1}$.  $B^{+}=\\left{A,B,C,D,E\\right}$ .  Since  $E$ is in  \\$B^+\\$,  $B\\rightarrow E$ holds. Therefore,  $C$ is extraneous in  $BC\\rightarrow E$.\n        *    Replace  $BC\\rightarrow E$ with  $B\\rightarrow E$.\n*    $B\\rightarrow D$ : No extraneous attributes.\n*    $D\\rightarrow A$ : No extraneous attributes.\n\n $F_{2}=\\left{A\\rightarrow B,A\\rightarrow C,A\\rightarrow D,B\\rightarrow D,B\\rightarrow E,D\\rightarrow A\\right}$ \n\n**Step 3: Remove redundant functional dependencies.** For each FD, check whether it can be derived from the others.\n\n*    $A\\rightarrow B$ : From \\${A \\\\rightarrow C, A \\\\rightarrow D, B \\\\rightarrow D, B \\\\rightarrow E, D \\\\rightarrow A}\\$ we cannot derive  $A\\rightarrow B$. Keep.\n*    $A\\rightarrow C$ : From \\${A \\\\rightarrow B, A \\\\rightarrow D, B \\\\rightarrow D, B \\\\rightarrow E, D \\\\rightarrow A}\\$ we cannot derive  $A\\rightarrow C$. Keep.\n*    $A\\rightarrow D$ :  We can derive  $A\\rightarrow D$ from  $A\\rightarrow B$ and  $B\\rightarrow D$. (Transitivity:  $A\\rightarrow B$  and  $B\\rightarrow D\\Rightarrow A\\rightarrow D$ ).  Remove  $A\\rightarrow D$.\n*    $B\\rightarrow D$ : From \\${A \\\\rightarrow B, A \\\\rightarrow C, B \\\\rightarrow E, D \\\\rightarrow A}\\$ we cannot derive  $B\\rightarrow D$. Keep.\n*    $B\\rightarrow E$ :  From  $B\\rightarrow D$ and  $D\\rightarrow A$, together with  $A\\rightarrow B,A\\rightarrow C$, we cannot derive  $B\\rightarrow E$. Keep. (In the previous step we reduced  $BC\\rightarrow E$ to  $B\\rightarrow E$. \\$B^+ = {A, B, C, D, E}\\$ and it included  $E$. Here  $B\\rightarrow E$ is a valid dependency.)\n*    $D\\rightarrow A$ : From \\${A \\\\rightarrow B, A \\\\rightarrow C, B \\\\rightarrow D, B \\\\rightarrow E}\\$ we cannot derive  $D\\rightarrow A$. Keep.\n\n $F_{c}=\\left{A\\rightarrow B,A\\rightarrow C,B\\rightarrow D,B\\rightarrow E,D\\rightarrow A\\right}$ \n\n**Step 4: Combine FDs with the same LHS.**\n\n*    Combine  $A\\rightarrow B,A\\rightarrow C$ into  $A\\rightarrow BC$.\n*    Combine  $B\\rightarrow D,B\\rightarrow E$ into  $B\\rightarrow DE$.\n\nTherefore, the canonical cover is:  $F_{c}=\\left{A\\rightarrow BC,B\\rightarrow DE,D\\rightarrow A\\right}$ \n\n### d. 3NF decomposition of the given schema based on the canonical cover (3NF Decomposition)\n\nThe 3NF decomposition algorithm creates a relation for each FD in the canonical cover and ensures that a key of the original relation is preserved.\n\nWe have the canonical cover \\$F\\_c = {A \\\\rightarrow BC, B \\\\rightarrow DE, D \\\\rightarrow A}\\$.\n\n1.  For each  $X\\rightarrow Y$ in the canonical cover, create a relation schema  $R_{i}=XY$.\n    *    $R_{1}=\\left(A,B,C\\right)$  (from  $A\\rightarrow BC$ )\n    *    $R_{2}=\\left(B,D,E\\right)$  (from  $B\\rightarrow DE$ )\n    *    $R_{3}=\\left(D,A\\right)$  (from  $D\\rightarrow A$ )\n2.  Find a key of the original relation \\$(A, B, C, D, E, G)\\$.\n    *   We already proved that \\$(AG)^+\\$ includes all attributes, so  $AG$ is a superkey. We must check whether  $AG$ is a minimal key.\n        *    $\\left(A\\right)^{+}=\\left{A,B,C,D,E\\right}$  (no  $G$)\n        *    $\\left(G\\right)^{+}=\\left{G\\right}$  (no other attributes)\n        *   Therefore,  $AG$ is a candidate key.\n3.  If no generated  $R_{i}$ fully contains a candidate key, create a new relation containing that candidate key.\n    *   \\$R\\_1 = (A, B, C)\\$ contains  $A$ but not  $G$.\n    *   \\$R\\_2 = (B, D, E)\\$ contains neither  $A$ nor  $G$.\n    *   \\$R\\_3 = (D, A)\\$ contains  $A$ but not  $G$.\n    *   Therefore, we must add a new relation \\$R\\_4 = (A, G)\\$ that contains the candidate key  $AG$.\n\nAs a result, the 3NF decomposition is:  $\\left{\\left(A,B,C\\right),\\left(B,D,E\\right),\\left(D,A\\right),\\left(A,G\\right)\\right}$ \n\n### e. BCNF decomposition using the original set of functional dependencies  $F$ (BCNF Decomposition)\n\nIn BCNF, for every nontrivial FD  $X\\rightarrow Y$,  $X$ must be a superkey. A 3NF decomposition always preserves dependencies, but a BCNF decomposition may not.\n\nOriginal FDs  $F=\\left{A\\rightarrow BCD,BC\\rightarrow DE,B\\rightarrow D,D\\rightarrow A\\right}$  relation schema  $R=\\left(A,B,C,D,E,G\\right)$ \n\nCheck each functional dependency:\n\n1.  ** $A\\rightarrow BCD$ **:\n    *   Compute \\$A^+\\$:\n        *    $A^{+}=\\left{A\\right}$ \n        *    $A\\rightarrow BCD\\Rightarrow A^{+}=\\left{A,B,C,D\\right}$ \n        *    $B\\rightarrow D$  (we already have  $D$ in \\$A^+\\$)\n        *    $D\\rightarrow A$  (we already have  $A$ in \\$A^+$)\n        *    $BC\\rightarrow DE$  ( since  $B,C$ are in \\$A^+$, add  $D,E$)  $\\Rightarrow A^{+}=\\left{A,B,C,D,E\\right}$ \n    *   \\$A^+\\$ does not include all attributes, so  $A$ is not a superkey (  $G$ is missing).\n    *    $A\\rightarrow BCD$ violates BCNF. Decompose using this dependency.\n    *    $R_{1}=\\left(A,B,C,D,E\\right)$  (LHS  $A$ and RHS  $BCD$, and  $E$ derivable via  $BC\\rightarrow DE$)\n        *   More precisely, treat  $A\\rightarrow BCD$ as the violation and decompose into \\$R\\_1 = (A, B, C, D)\\$ and \\$R\\_{remainder} = (A, E, G)\\$. Although  $A\\rightarrow BCD$ can be split into  $A\\rightarrow B,A\\rightarrow C,A\\rightarrow D$. Here we decompose into a relation containing the RHS  $BCD$ of  $A\\rightarrow BCD$ and another relation containing the remaining attributes along with the LHS.\n        *    A BCNF decomposition usually produces one relation containing the LHS and RHS of the violating FD, and another relation formed by combining the LHS with the remaining attributes from the original relation.\n        *    $R_{A}=\\left(A,B,C,D\\right)$  (from  $A\\rightarrow BCD$ )\n        *    $R_{rem}=\\left(A,E,G\\right)$  (remove  $BCD$ from the original  $R$ while retaining  $A$)\n        *    Project  $F$ onto  $R_{A}$ and \\$R\\_{rem}\\$.\n            *    $F_{R_{A}}=\\left{A\\rightarrow BCD,B\\rightarrow D,D\\rightarrow A\\right}$ \n            *    $F_{R_{rem}}=\\left{\\right}$  (G is unrelated. E could be derived from A before, but  $A\\rightarrow E$ is not an FD over \\$R\\_{rem}\\$)\n2.  **BCNF check for \\$R\\_A = (A, B, C, D)\\$**:\n    *    $F_{R_{A}}=\\left{A\\rightarrow BCD,B\\rightarrow D,D\\rightarrow A\\right}$ \n    *   ** $A\\rightarrow BCD$ **: $A^+$ over the whole schema is $A,B,C,D,E$, but $A^+$ over $R_{A}$ is ${A, B, C, D}$. $A$ is a superkey of $R_{A}$. Since $A$ determines all attributes of $R_{A}$, this FD satisfies BCNF. (Wait, although $A^+$ contains all attributes of $R_{A}$, $A$ might not be a candidate key of $R_{A}$. For example, since $D\\rightarrow A$ holds, $D$ is also a candidate key of $R_{A}$. $D\\rightarrow A\\Rightarrow D\\rightarrow A\\rightarrow BCD\\Rightarrow D\\rightarrow ABCD$ . Therefore, both $A$ and $D$ are candidate keys of $R_{A}$. Since the LHS of $A\\rightarrow BCD$ is a superkey, BCNF is satisfied.)\n    *   ** $B\\rightarrow D$ **: Compute \\$B^+\\$ with respect to  $R_{A}$.  $B^{+}=\\left{B,D,A,C\\right}$ . Since \\$B^+\\$ contains all attributes \\${A, B, C, D}\\$ of  $R_{A}$,  $B$ is a superkey of  $R_{A}$. Therefore,  $B\\rightarrow D$ satisfies BCNF.\n    *   ** $D\\rightarrow A$ **: Compute \\$D^+\\$ with respect to  $R_{A}$.  $D^{+}=\\left{D,A,B,C\\right}$ . Since \\$D^+\\$ contains all attributes \\${A, B, C, D}\\$ of  $R_{A}$,  $D$ is a superkey of  $R_{A}$. Therefore,  $D\\rightarrow A$ satisfies BCNF.\n    *   Therefore, \\$R\\_A = (A, B, C, D)\\$ is in BCNF.\n3.  **BCNF check for \\$R\\_{rem} = (A, E, G)\\$**:\n    *   \\$F\\_{R\\_{rem}}\\$ has no nontrivial dependencies (dependencies from the original  $F$ that use only the attributes of \\$R\\_{rem}\\$).  Although  $A\\rightarrow E$ can be derived by transitivity from  $A\\rightarrow BCD$ and  $BC\\rightarrow DE$,  $E$ is determined by  $B,C$, so  $A$ alone is insufficient.\n    *   To address the BCNF violations  $A\\rightarrow BCD$ and  $BC\\rightarrow DE$, create relations that contain all attributes determined by  $A\\rightarrow BCD$  (or  $A\\rightarrow B$ ,  $A\\rightarrow C$ ,  $A\\rightarrow D$ ) and  $BC\\rightarrow DE$.\n\nA BCNF decomposition goes through a more involved process. When there is a violating dependency  $X\\rightarrow Y$, decompose relation  $R$ into  $R_{1}=XY$ and  $R_{2}=R-Y$. Then repeat this process for each new relation.\n\nStart again: relation schema  $R=\\left(A,B,C,D,E,G\\right)$   $F=\\left{A\\rightarrow BCD,BC\\rightarrow DE,B\\rightarrow D,D\\rightarrow A\\right}$ \n\n1.  ** Check  $A\\rightarrow BCD$ **: \\$A^+\\$ is not a superkey of  $R$ (missing G).\n    *    $R_{1}=\\left(A,B,C,D\\right)$  (from  $A\\rightarrow BCD$ )\n    *    $R_{rest}=\\left(A,E,G\\right)$  (remove  $BCD$ from the original  $R$ and include  $A$)\n2.  **FDs for \\$R\\_1 = (A, B, C, D)\\$**:\n    *    $A\\rightarrow BCD$  (LHS:  $A$ ,  $A^{+}$  of  $R_{1}$  is  $\\left{A,B,C,D\\right}$ , so  $A$  is a superkey for  $R_{1}$ . BCNF satisfied.)\n    *    $B\\rightarrow D$  (LHS:  $B$ ,  $B^{+}$  of  $R_{1}$  is  $\\left{B,D,A,C\\right}$ , so  $B$  is a superkey for  $R_{1}$ . BCNF satisfied.)\n    *    $D\\rightarrow A$  (LHS:  $D$ ,  $D^{+}$  of  $R_{1}$  is  $\\left{D,A,B,C\\right}$ , so  $D$  is a superkey for  $R_{1}$ . BCNF satisfied.)\n    *    $R_{1}$ is in BCNF.\n3.  **FDs for \\$R\\_{rest} = (A, E, G)\\$**:\n    *   Check whether there are any nontrivial dependencies from the original  $F$ that involve only the attributes of \\$R\\_{rest}$.\n    *    $F=\\left{A\\rightarrow BCD,BC\\rightarrow DE,B\\rightarrow D,D\\rightarrow A\\right}$ \n    *    Although  $A\\rightarrow E$ can be derived by transitivity from  $A\\rightarrow BCD$ and  $BC\\rightarrow DE$, this is not a direct dependency over \\$R\\_{rest}$. That is, deriving  $A\\rightarrow E$ requires  $B$ and  $C$.\n    *    $A^{+}$  (on  $R_{rest}$ ) should include  \\${A, E, G}\\$.\n        *    $A^{+}=\\left{A\\right}$ \n        *    $A\\rightarrow BCD$  (but  $B,C,D$ are not in \\$R\\_{rest}$)\n        *    $BC\\rightarrow DE$  (B, C are missing, so cannot use)\n        *    $B\\rightarrow D$  (no B)\n        *    $D\\rightarrow A$  (no D)\n    *   In fact, over \\$R\\_{rest}=(A, E, G)\\$ there are no nontrivial dependencies implied by  $F$.\n    *   Therefore, \\$R\\_{rest}=(A, E, G)\\$ is in BCNF.\n\nThe BCNF decomposition is:  $\\left{\\left(A,B,C,D\\right),\\left(A,E,G\\right)\\right}$ \n\nThis decomposition has the lossless join property. However, we must verify whether it also has the dependency preservation property. Some dependencies from the original  $F$ (e.g.,  $BC\\rightarrow DE$ ) may not be fully contained within any one of the decomposed relation schemas.\n\n $BC\\rightarrow DE$ :  $BC$ is in \\$(A, B, C, D)\\$, but  $E$ is not.  $E$ is in \\$(A, E, G)\\$, but  $BC$ is not. Therefore,  $BC\\rightarrow DE$ is not preserved. A BCNF decomposition does not always preserve dependencies.\n\nFinal BCNF decomposition:  $\\left{\\left(A,B,C,D\\right),\\left(A,E,G\\right)\\right}$"
    }
  ]
}