免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
论坛 数据库技术 Oracle DB
最近访问板块 发新帖
查看: 887 | 回复: 0
打印 上一主题 下一主题

DB [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-20 09:48 |只看该作者 |倒序浏览
第一范式(1NF):【每一列都不可再分割,列与列之间含义不重复】

第二范式(2NF):【基于1NF,每条记录都有主键能加以区分】

第三范式(3NF):【基于2NF,某个具体的实体/表中,非主键属性都完全由主键决定】
假如,有以下两张表:
  职工表(职工ID pk,职工名册,部门ID,部门名称)
此时职工表.部门名称就与部门表.部门名称重复,造成冗余。
职工表就造成以下依赖关系:
职工ID(主键) -> 部门ID(非主键) -> 部门名称(非主键)
此时就应该把部门ID,部门名称单独建一个表,并将部门名称从职工表中移除。结果如下
  部门表(部门ID pk,部门名称)
  职工表(职工ID pk,职工名册,部门ID)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP