- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
什么是 KISS(Keep it Simple, Stupid)方法来记住 Boyce-Codd 范式是什么以及如何采用非规范化表和 BCNF?
Wikipedia的信息:对我帮助不大。
最佳答案
Chris Date的定义其实很好,只要你理解他的意思即可:
您的数据必须分解为单独的、不同的属性/列/值,这些属性/列/值不依赖于任何其他属性。你的全名是一个属性。你的生日是一个属性。您的年龄不是属性,它取决于当前日期,该日期不属于您的生日。
每个属性都是一个事实,而不是事实的集合。更改属性中的一位会更改整个含义。你的生日是事实。你的全名是事实吗?好吧,在某些情况下是这样,因为如果您更改姓氏,您的全名就会不同,对吗?但是对于系谱学家来说,你有一个姓氏和一个姓氏,如果你改变了你的姓氏,你的姓氏就不会改变,所以它们是不同的事实。
有一个属性是特殊的,它是一个键。键是一个属性,它对于数据中的所有信息都必须是唯一的,并且绝不能更改。您的全名不是 key ,因为它可以更改。您的社会保险号码不是关键,因为它们会被重复使用。您的 SSN 加生日不是键,即使该组合永远不能重复使用,因为属性不能是两个事实的组合。 GUID 是一个键。您递增但永远不会重复使用的数字是 key 。
仅凭 key 就足以[并且是必要的!] 来识别您的值;您不能用不同的键表示相同的数据,键列的子集也不足以识别事实。假设您有一个包含 GUID 键、名称和地址值的地址簿。如果相同的名称代表不同的人并且不是“相同的数据”,则可以使用不同的键出现两次相同的名称。如果会计部门的 Mary Jones 将她的名字更改为 Mary Smith,则销售部门的 Mary Jones 也不会更改她的名字。另一方面,如果 Mary Smith 和 John Smith 有相同的街道地址并且确实是同一个地方,则不允许这样做。您必须使用街道地址和新 key 创建新的键/值对。
您也不允许将这个新的单一街道地址的键用作地址簿中的值,因为现在同一个街道地址键将被表示两次。相反,您必须使用地址簿键和街道地址键的值创建第三个键/值对;您可以通过在这组值中匹配他们的书本键和地址键来找到一个人的街道地址。
除了标识您的值的键之外,必须没有其他内容。例如,如果允许您使用“泰姬陵”地址(假设只有一个),则不允许在同一记录中使用城市值,因为如果您知道地址,您也会知道这座城市。这也将开启在不同城市拥有多个泰姬陵的可能性。相反,您必须再次创建一个具有唯一值的辅助位置键,例如泰姬陵、华盛顿特区的白宫等,以及它们所在的城市。或者禁止城市独有的“地址”。
关于database - Boyce-Codd 范式的 KISS 描述是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/539324/
在一个环境中,我有 pandas 版本 0.17.0 和 numpy 版本 1.10.1。在另一个环境中,我有 pandas 版本 0.18.1 和 numpy 版本 1.10.4。 我运行这段代码
This question already has answers here: Default stringify for objects, equivalent to Java's toString
我一直在尝试为我的profile命令嵌入设置一个人们可以更改的简历。我认为它应该有效,但我的代码似乎有问题。 相关代码如下: const PREFIX = '!'; var bio = {}; cli
我正在尝试获取网站图标、网站标题和外部 URL 列表的描述,最好使用 jquery。我已经成功地为我的网址同步了谷歌的图标服务,任何人都可以阐明如何实现网站标题和描述吗?这是我到目前为止获得图标的内容
我在尝试运行代码时收到错误。找不到问题出在哪里。我可能遗漏了一些小细节,如果您能纠正它那就太好了。 计算Servlet import java.io.IOException; impo
我的数据库中有两个字段,一个是描述(TEXT),另一个是short_desc(VARCHAR-200)。 当我显示搜索结果时,我显然使用了short_desc,当有人点击该项目时,他们会得到完整的描述
当我尝试通过ajax和Jquery调用 Controller 上的save方法时,我正在使用Spring MVC、Jquery、Hibernate和tomcat。单击“保存”按钮时,我在 tomcat
我试图使用describe()来获取一些描述性统计数据,但获取了应该是数字的nan值。 我尝试使用 axis=0 或 axis=1,而 axis=1 产生了正确的数值,但这不是正确的数值我需要; ax
我有超过 1 亿个字符串要存储在文件系统中。与字符串 (~255Chars utf8) 一起,将有两个日期和一些定义其属性的整数值。 我可以将它们放在一个 CSV 文件中,但它会很大。我可以将几个较小
有没有办法将 JavaScript 合并到 Jenkins 顶部的描述字段中? 每当我添加脚本标签时,当您查看源代码时,它都会被 Jenkins 删除。 如果有人有建议或方向指出我,那就太好了。
您如何获得 SEH 的名称和/或描述?异常无需必须将字符串硬编码到您的应用程序中? 我尝试使用 FormatMessage(),但它有时会截断消息,即使您指定忽略插入也是如此: __asm { //
如果我在 MySQL 中使用 CREATE TRIGGER 语法创建一个触发器,我该如何附加注释来描述它?我的意思是在声明中或之后对我来说是一样的。 我想不通。对于表格,您可以在声明末尾添加 COMM
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
当开发多媒体应用或者游戏应用的时候,需要使用音量控制键来设置程序的音量大小。在Android系统中有多中音频流,通过Activity中的函数 setVolumeControlStream(int s
Slick DSL 允许通过两种方式在表中创建可选字段。 对于这个案例类: case class User(id: Option[Long] = None, fname: String, lname:
如果不属于默认命名空间,我如何描述 pod 信息。使用默认命名空间我没有任何问题。 但我想获得与命名空间对齐的特定 pod 的信息。 但是,当我想描述我可以制作的同一个 pod 时,请参阅 我尝试使用
在我使用过的几乎所有 vim 副本中,程序都会在替换文本后给出更改的描述。 (例如,将显示类似“20 行 92 个替换”之类的内容。) 我现在正在使用默认情况下不这样做的 vim 副本。 是否有一个简
我正在编写规范,需要描述一些 JSON 对象。单独的文本和选项卡往往会使大型 JSON 变得过于困惑。是否有任何在线(最好)工具可以创建类似于 http://www.json.org/ 上的图表的工具
我正在尝试通过 DNS 将我的 Kubernetes 部署连接在一起。 我有一个 Java (Spring Boot) 部署和一个 javascript (node.js) 部署,两者都通过默认的 C
我只是在学习 WebGL 图形编程。 我正在检查包含该语句的某人的代码 // multiply the position by the matrix. gl_Position = vec4((u_ma
我是一名优秀的程序员,十分优秀!