- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《数据库正规化和设计技巧
在动态网站的设计中,数据库设计的重要性不言而喻。如果设计不当,查询起来就非常吃力,程序的性能也会受到影响。无论你使用的是mysql或者oracle数据库,通过进行正规化的表格设计,可以令你的php target=_blankphp代码更具可读性,更容易扩展,从而也会提升应用的性能。
简单说来,正规化就是在表格设计时,消除冗余性和不协调的从属关系。在本文中,我将通过五个渐进的过程来告诉你在设计中应该了解的正规化技巧。从而建立一个可行而且效率高的数据库。本文也会详细分析一下可以利用的关系类型。
这里假定我们要建立一个用户信息的表格,其中要存储用户的名字、公司、公司地址和一些个人的收藏夹或url。在开始时,你可能定义一个如下的表格结构:
零状态形式
users
name company company_address url1 url2
joe abc 1 work lane
jill xyz 1 job street
由于没有进行任何的正规化处理,我们将这种形式的表称为零状态形式的表。留意其中的url1和url2字段---如果我们在应用中需要第三个url呢?这样你就要在表格中多加一列,很明显,这不是一个好办法。如果你要创建一个富有扩展性的系统,你就要考虑使用第一个正规化的形式,并且应用到该表格中。
第一级正规化形式
1.消除每个表格中重复的组
2.为每套相关的数据建立一个独立的表格
3.使用一个主键来标识每套相关的数据
以上的表格明显违反了上面第一条的规定,那么第三条的主键又是什么意思呢?很简单,它只是在每个记录中加入一个唯一的、自动增加的整型值。通过这个值,就可以将两个姓名一样的记录区分开来。通过应用第一级正规化形式,我们得到了以下的表格:
users
userid name company company_address url
1 joe abc 1 work lane
1 joe abc 1 work lane
2 jill xyz 1 job street
2 jill xyz 1 job street
现在我们的表格可以说已经处在第一级正规化的形式了,它已经解决了url字段的限制问题,不过这样的处理后又带来了一个新的问题。每次在user表中插入一条记录的时候,我们都必须重复所有的公司和用户数据。这样不仅令数据库比以前大了,而且很容易出错。因此还要经过第二级正规化处理。
第二级正规化形式
1.为应用在多条记录的字段建立独立的表格
2.通过一个foreign key来关联这些表格的值
我们将url的值放在一个独立的表格中,这样我们就可以在以后加入更多的数据,而无需担心产生重复的值。我们还通过主键值来关联这些字段:
users
userid name company company_address
1 joe abc 1 work lane
2 jill xyz 1 job street
urls
urlid reluserid url
1 1
2 1
3 2
4 2
如上所示,我们创建了独立的表格,users表中的主键userid现在与url表中的foreign key reluserid关联。现在的情况好象已经得到了明显的改善。不过,如果我们要为abc公司加入一个员工记录呢?或者更多,200个?这样我们就必须重复使用公司名和地址,这明显不够冗余。因此我们将应用第三级正规化方法:
第三级正规化形式
1.消除不依赖于该键的字段
公司名及地址与user id都是没有关系的,因此它们应用拥有自己的公司id:
users
userid name relcompid
1 joe 1
2 jill 2
companies
compid company company_address
1 abc 1 work lane
2 xyz 1 job street
urls
urlid reluserid url
1 1
2 1
3 2
4 2
这样我们就将companies表中的主键comid和users表中名字为relcompid的foreign key关联起来,就算为abc公司加入200个员工,在companies中也只有一条记录。我们的users和urls表可以不断地扩大,而无需担心插
您可能关注的文档
- 《数学模型数学建模第六次作业图论组合优化实验.docx
- 《数学游戏在课堂教学中的应用浅析.doc
- 《教育学原理复习指南.doc
- 《教育学原理复习题含答案.doc
- 《教育学原理复习题答案:总结计划汇报设计纯word可编辑.doc
- 《数学游戏走进小学数学课堂教学.doc
- 《数学模型在日常生活中的应用.docx
- 《教育学原理教师与学生.doc
- 《教育学原理期末考试样卷.doc
- 《数学电子书.docx
- 【完整版】2020-2025年中国内镜诊疗器械行业竞合策略制定与实施研究报告.pdf
- 【完整版】2020-2025年中国微创医疗器械行业可持续发展战略制定与实施研究报告.pdf
- 南微医学:南微医学科技股份有限公司2022年年度报告摘要.pdf
- 南微医学:南微医学科技股份有限公司2020年年度报告摘要.pdf
- 【完整版】2020-2025年中国内镜诊疗器械行业市场创新战略制定与实施研究报告.pdf
- 【完整版】2020-2025年中国微创医疗器械行业市场营销及渠道发展趋势研究报告.pdf
- 【完整版】2020-2025年中国微创医疗器械行业提升企业核心竞争力战略研究报告.pdf
- 【完整版】2020-2025年中国微创医疗器械行业全国市场开拓策略制定与实施研究报告.pdf
- 【完整版】2020-2025年中国微创医疗器械行业竞合策略制定与实施研究报告.pdf
- D企业车辆管理规定范本.pdf
最近下载
- (正式版)D-L∕T 860.74-2014 电力自动化通信网络和系统 第7-4部分:基本通信结构 兼容逻辑节点类和数据类.docx VIP
- 钢格栅板及配套件国家标准.pdf
- 防火墙运维.docx VIP
- T_BPMA 0010—2021_现制现售净水机卫生管理规范.pdf VIP
- 有害物质识别与评估控制程序.doc VIP
- 胃脘痛•胃痞病(胃息肉)中医临床路径标准住院表单.docx VIP
- JAVA应用系统开发规范概要1.doc VIP
- 临床诊疗指南(肿瘤科分册).doc
- 剑桥少儿英语一级上unit15_a_happy_new_year.ppt VIP
- 2024年05月广东惠州市生态环境局博罗分局和博罗县污染防治攻坚战总指挥部办公室公开招聘编外人员笔试历年典型题及考点剖析附带答案含详解.docx VIP
文档评论(0)