- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我刚刚阅读了 DBMS 中 3NF 的定义,它指出:
函数依赖 X --> A 是允许的,如果:1. X 是 super 键。2. A 是某个键的一部分。
我有两个疑问:
a:我不明白第二个条件对消除异常有何用处。为什么有 BCNF 形式,相反我们可以定义 3NF 形式来不具有第二个条件。
我明白要移除传递依赖。如果 Y --> Z 并且 X 是主键。然后存在传递依赖,因为 X --> Y --> Z 意味着我们不能存储 (X,Y) 的值,除非我们知道 Z。
b:请解释移除 3NF 中的第二个条件将如何移除异常和/或限制冗余。
最佳答案
“函数依赖 X --> A 是允许的,如果:1. X 是一个 super 键。2. A 是某个键的一部分。”
您定义的第二个条件错误。 A
应该是一个非素数 属性(即它不应该是满足 3NF 的 key 的一部分)。
事实上,理解 3NF 的更好方法是 -
给定函数依赖 X->Y
如果 Y
是一个非素数 属性然后 X
必须是 superkey。
(请注意,这确保没有传递依赖)
另一方面 BCNF 是-
对于 每个 函数依赖 X->Y
左侧 (X
) 必须是一个 super 键(无论右边(Y)
是质数还是非质数都没有关系)
现在你的第一个疑问
“为什么有 BCNF 形式,而不是我们可以定义 3NF 形式来不具有第二个条件?”是的,如果你去掉 3NF 的第二个条件(即 Y
应该是非素数属性)则等价于 BCNF。但是你为什么要这样做呢? 有时您无法减少与 BCNF 的关系(因为并不总是能够获得保留依赖关系的 BCNF 分解),那么将其减少到 3NF 至少会更好然后让它在 2NF 中
例如-
R=(J,K,L)
F={JK->L,L->K}
这里我们有 2 个候选键 - JK
和 JL
并且 R
不在 BCNF 中。 R
的任何分解都无法保留 JK->L
。这意味着对 JK->L
的测试需要连接。所以有些情况下 -
解决方案:定义一个较弱的范式,称为 3NF。 3NF 中始终存在无损连接、保留依赖关系的分解。
我真的不明白你的第二个疑问 - “...3NF 如何消除异常和/或限制冗余”。 3NF 将消除冗余购买,消除任何传递依赖!
This也可能有一些帮助。
关于database - DBMS 中的第三范式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30982590/
我想知道使用 C# 自定义属性和 AOP 框架(如 PostSharp)之间的区别。 如何在它们之间进行选择? 最佳答案 自定义属性是在代码元素上声明元数据的方法,这些元素可以被系统的其他元素理解,包
我正在阅读各种中间形式,但除了类似 wiki 的条目之外,我无法获得有关 A-normal 形式的信息。这里有人知道这件事或有关于它的好资源吗? 最佳答案 见 Administrative norma
使用 RESTful 服务,您可以创建、读取、更新和删除资源。当您处理数据库 Assets 之类的东西时,这一切都很有效 - 但这如何转换为流数据呢? (或者确实如此?)例如,就视频而言,将每一帧视为
我有大约 25 个 Activity ,现在我需要编写一个在大约 3 到 5 个 Activity 中相同的函数,现在我可以使用这些 OOP 范例中的任何一个吗? 静态方法 单例类(应用程序类) 父类
我最近遇到了这个类,并对 getters 和 setter 已实现。 我以前没有遇到过这种情况,欢迎提出第二点意见。 您认为这是一个好的范例吗?不好吗?是邪恶的吗? 标题: class Too
我在多重继承菱形方案下组织了 4 个类。 BASE / \ / \ Deriv1 Deriv2
使用 RESTful 服务,您可以创建、读取、更新和删除资源。当您处理数据库 Assets 之类的东西时,这一切都很有效 - 但这如何转换为流数据呢? (或者确实如此?)例如,就视频而言,将每一帧视为
SQL 数据库中有两个函数依赖关系。 a) 部分函数依赖:非键列依赖于复合主键中的一些列,但不是所有列。 b) 传递函数依赖:任何非键列依赖于其他非键列。 对于一个好的 SQL 数据库。 规则 1:列
现在,我正在使用 PHP/Laravel 进行编程,但我认为这可能适用于任何其他 MVC 框架。我将使用 PHP/Laravel 语法。 我有一个需要非常基本的审计跟踪的应用程序。数据库中的审计表(a
我阅读了以下示例,该关系 A(X,Y,Z,P,Q,R) 具有以下函数依赖性。 为什么这是在 1NF 中? 谁能帮帮我? 最佳答案 该图不是正常符号。我想箭头指向 FD 的确定属性。我假设不是来自盒子的
1 概述 一般地,在进行数据库设计时,应遵循三大原则,也就是我们通常说的三大范式,即第一范式要求确保表中每列的原子性,也就是不可拆分;第二范式要求确保表中每列与主键相关,而不能只与主键的某部分相关
我正在开发一个流规则引擎,我的一些客户有几百条规则,他们想对到达系统的每个事件进行评估。规则是纯(即无副作用) bool 表达式,它们可以任意深度嵌套。 客户在运行时创建、更新和删除规则,我需要动态检
Rails 使用 MVC 范式。模型、 View 和 Controller 很有趣,实际上只有 Controller 才有“应用程序”或父 Controller 。实际上,rails 中有一个 app
该文件如下所示。我需要读取它们并将它们存储在数据结构中(可能是邻接表)。但我不知道如何忽略无用的注释并在 'p cnf' 之后开始阅读。 c This Formula is generated by
这可能是重复的,因为我无法在脑海中找到单词来激发查询。 我每天都在使用 PHP、C#、JavaScript,但只有在 JavaScript 中我才能像疯子一样开箱即用。 例如,给定一个简单的(我知道它
谁能向我解释 NSAttributedString 如何正确遵循 MVC 范式?我知道它不是从 NSString 继承的,但它仍然是一个字符串,所以我会说这是我模型的一部分。但是,在谈论 MVC 时,
我正在努力加深对副作用以及应如何控制和应用它们的理解。 在下面的航类列表中,我想为每个满足条件的航类设置一个属性: IEnumerable fResults = getResultsFromProvi
这是我一直怀疑的事情。考虑以下代码段。 class A(object): def check(self): super(A, self).check() pri
在关系型数据库设计中,例如有schema S(banker, bname, customer)和function dependencies (FDs) 银行家->名字customer,bname->银
我已经对设计模式进行了一段时间的思考,现在我才刚刚开始了解如何将其中一些更慎重地融入到我的开发工作中。然而,我仍然对他们在本书开头对 MVC 的处理以及它与本书其余部分的关系感到困惑。 我使用过的大多
我是一名优秀的程序员,十分优秀!