📜  属性闭合算法及其应用

📅  最后修改于: 2021-09-08 16:01:53             🧑  作者: Mango

FD 的集合 F 的闭包是可以从 F 推断出的所有 FD 的集合 F + 。它也称为函数依赖的完整集合。用 F +表示。

算法:属性闭包集

Algorithm to compute a+, the closure of a under F
Result:= a;
while (changes to Result) do  
    for each B → Y in F do
        Begin
            if B ⊆  Result  then  Result := Result ∪  Y  
        End

属性闭包的利用——

  • 测试给定的属性是否是超级键/候选键。
  • 我们可以检查 FD X → Y 是否成立。
  • 找出 F +的另一种方法。
  1. 测试属性是否为超键。

    例子 :
    令 R = (A, B, C, G, H, I) 和 FD 的集合是 F = { A → B, A → C, CG → H, CG → I, B → H}

    找出 (AG) + .

    结果 = {A, G}

    第一个循环:

    A → B includes B in the Result as A⊆ Result (which is AG), so Result := Result ∪ B. 
    Hence Result = {A, G, B}
    A → C causes Result to become ABCG.
    CG → H causes the Result to become ABCGH.
    CG → I causes the Result to become ABCGHI.
    B → H causes Result to become ABCGHI.

    第二个循环:

    A → B causes the Result to be unchanged i.e. ABCGHI (B is already part of the Result).
    A → C causes Result to be unchanged.
    CG → H causes the Result to be unchanged.
    CG → I causes the Result to be unchanged.
    B → H causes Result to be unchanged.

    在第二个循环结束时,结果不会改变,因此退出循环。

    (AG) + = {A, B, C, G, H, I}

    结论: AG 是一个超级键,因为它可以确定所有其他属性。

  2. 检查 Fd 是否存在:

    例子 :
    令 R = (A, B, C, G, H, I) 和 FD 的集合是 F = { A →B, A → C, CG → H, CG → I, B → H}

    检查 HB → 我持有与否

    结果 = {H, B}

    第一个循环:

    In A → B as A ⊆ Result (which is HB) so nothing will be added.
    In A → C nothing added.
    CG → H (CG ⊆ Result (which is HB) so nothing added)
    CG → I nothing added.
    B → H nothing added.

    在第一个循环结束时,结果不会改变,因此退出循环。

    结论: HB→我不持有。

  3. 找到 FD 闭包的另一种方法 (F + )。

    例子 :
    给定一个关系 R (A, B, C, D, E, F) 和一组 FD F: {A → BC, E → CF, B → E, CD → EF}

    找出 {A, B} + 的闭包

    步骤 1:结果 = AB

    步骤 2:第一个循环

    Result = ABC for A → BC, A ⊆ Result so Result = Result ∪ BC.
    Result = ABC for E→ CF, E ∉ Result so Result = Result.
    Result = ABCE for B → E, B ⊆Result so Result = Result ∪ E.
    Result = ABCE for CD → EF, CD ∉ Result so Result = Result.

    步骤2之前的结果是AB,步骤2之后的结果是不同的ABCE,所以重复步骤2。

    第 3 步:第二个循环

    Result = ABCE for A → BC, A ⊆ Result so Result = Result ∪ BC.
    Result = ABCEF for E → CF, E ⊆ Result so Result = Result ∪ CF.
    Result = ABCEF for B → E, B ⊆ Result so Result = Result ∪ E.
    Result = ABCEF for CD → EF, CD ∉ Result so Result = Result.

    第3步之前的结果是ABCE,第3步之后的结果是ABCEF,不同,重复第3步。

    第 4 步:第三个循环

    Result = ABCEF for A → BC, A ⊆ Result so Result = Result ∪ BC.
    Result = ABCEF for E → CF, E ⊆ Result so Result = Result ∪ CF.
    Result = ABCEF for B → E, B ⊆ Result so Result = Result ∪ E.
    Result = ABCEF for CD → EF, CD ∉ Result so Result = Result.

    步骤 4 之前的结果是 ABCEF,步骤 3 之后的结果是 ABCEF,这是相同的,所以停止。

    所以 {A, B} + 的闭包是 {A, B, C, E, F}。

    结论:对于每个属性/属性集,我们都可以找到闭包。这导致 F +