数据库正规化和计划本领[MSSQL防范]
本文“数据库正规化和计划本领[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
数据库正规化和计划本领
在动态网站的计划中,数据库计划的重要性不言而喻.假如计划不当,查询起来就非常吃力,程序的性能也会遭到影响.无论你利用的是MySQL大概Oracle数据库,通过举行正规化的表格计划,可以令你的PHP代码更具可读性,更简单扩大,从而也会晋升利用的性能.
简单说来,正规化就是在表格计划时,消除冗余性和不调和的从属关系.在本文中,我将通过五个渐进的历程来奉告你在计划中应当理解的正规化本领.从而成立一个可行并且效率高的数据库.本文也会具体解析一下可以操纵的关系范例.
这里假定我们要成立一个用户信息的表格,此中要存储用户的名字、公司、公司地址和一些个人的珍藏夹或url.在开始时,你大概定义一个以下的表格构造:
零状况情势
users
name company company_address url1 url2
Joe ABC 1 Work Lane abc.com xyz.com
Jill XYZ 1 Job Street abc.com xyz.com
由于没有举行任何的正规化处理,我们将这种情势的表称为零状况情势的表.留神此中的url1和url2字段---假如我们在利用中需求第三个url呢?这样你就要在表格中多加一列,很明显,这不是一个好办法.假如你要成立一个富有扩大性的系统,你就要考虑利用第一个正规化的情势,并且利用到该表格中.
第一级正规化情势
1.消除每个表格中反复的组
2.为每套相关的数据成立一个独立的表格
3.利用一个主键来标识每套相关的数据
以上的表格明显违反了上面第一条的规定,那么第三条的主键又是什么意思呢?很简单,它只是在每个记录中加入一个唯一的、自动增添的整型值.通过这个值,便可以将两个姓名一样的记录区脱离来.通过利用第一级正规化情势,我们得到了以下的表格:
users
userId name company company_address url
1 Joe ABC 1 Work Lane abc.com
1 Joe ABC 1 Work Lane xyz.com
2 Jill XYZ 1 Job Street abc.com
2 Jill XYZ 1 Job Street xyz.com
目前我们的表格可以说已经处在第一级正规化的情势了,它已包办理了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 abc.com
2 1 xyz.com
3 2 abc.com
4 2 xyz.com
如上所示,我们成立了独立的表格,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 abc.com
2 1 xyz.com
3 2 abc.com
4 2 xyz.com
这样我们就将companies表中的主键comId和users表中名字为relCompId的foreign key关联起来,就算为ABC公司加入200个员工,在companies中也只有一条记录.我们的users和urls表可以不断地扩大,而无需耽忧插入不必要的数据.大部份的开辟者都认为经过三步的正规化就充足了,这个数据库的计划已经可以很便利地处理整个企业的负担,此见解在大大都的情形下是精确的.
我们可以留神一下url的字段--你注意到数据的冗余了吗?假如给用户用户输入这些url数据的HTML页面是一个文本框,可肆意输入的话,这并没有问题,两个用户输入一样珍藏夹的概率较少,不过,假如是通过一个下拉式的菜单,只让用户挑选两个url输入,大概更多一点.这种情形下,我们的数据库还可以举行下一级别的优化--第四步,关于大大都的开辟者来说,这一步都是忽视的,因为它要依靠一个很分外的关系--一个多对多的关系,这在我们的利用中是还没有碰到过的.
数据关系
在定义第四个正规化的情势前,我想首先提一下三种基本的数据关系:一对一,一对多和多对多.我们回头看一下经过第一个正规化的users表.如果我们将url的字段放在一个独立的表中,每次在users表中插入一个记录,我们就会在urls表中插入一行.我们将得到一个一对一的关系:用户表中的每一行,都将在urls表中找到呼应的一行.关于我们的利用来说,这既不实用也不尺度.
然后看看第二个正规化的例子.关于每个用户记录,我们的表格答应有多个urls的记录与之关联.这是一个一对多的关系,这是一个很常见的关系.
关于多对多的关系来说,就有点复杂了.在我们的第三个正规化情势的例子中,我们的一个用户与很多的url有关,而我们想将该构造变成允很多个用户与多个的urls有关,这样我们便可以得到一个多对多的构造.在谈论前,我们先看看表格构造会有些什么改变
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 url
1 abc.com
2 xyz.com
url_relations
relationId relatedUrlId relatedUserId
1 1 1
2 1 2
3 2 1
4 2 2
为了进一步减低数据的冗余,我们应用第四级正规化情势.我们成立了一个颇奇特的url_relations表,里面的字段均为主键大概foreign key.通过这个表,我们便可以消除urls表中的反复项目.以下是第四个正规化情势的具体要求:
第四个正规化情势
1.在一个多对多的关系中,独立的实体不能存放在同一个表格中
由于它仅利用于多对多的关系,因此大大都的开辟者可以忽视这条规定.不过在某些情形下,它是非常实用的,这个例子就是这样,我们通过将相同的实体别离出来,并且将关系移到它们自己的表格中,从而改良了urls表格.
为了令你更简单懂得,我们举个具体的例子,以下将用一个SQL语句挑选出全部属于joe的urls:
SELECT name, url FROM users, urls, url_relations WHERE url_relations.relatedUserId = 1 AND users.userId = 1 AND urls.urlId = url_relations.relatedUrlId
假如我们想要遍历每个人的个人信息和url信息,我们可以这样做:
SELECT name, url FROM users, urls, url_relations WHERE users.userId = url_relations.relatedUserId AND urls.urlId = url_relations.relatedUrlId
第五级正规化情势
还有一级正规化的情势,它并不常见,有点高深,并且在大部份的情形下都是不必要的.它的原则是:
1.本来的表格必须可以通过由它别离出去的表格重新构建
利用这个规定的好处是,你可以确保不会在别离的表格中引入多余的列,全部你成立的表格构造都与它们的实际需求一样大.利用这条规定是一个好习惯,不过除非你要处理一个非常大型的数据,不然你将不需求用到它.
但愿这篇文章对你有效,并且可以帮忙你在全部的项目中利用这些正规化的规定.你大概想知道这些办法是从哪来的,我可以奉告你,前面三个正规化的规定是1972年,Dr. E.F. Codd在他的论文"进一步正规化数据库的关系模子中"提出的,别的的规定是经过后来的集公道论和关系数学家理论化的. 评论:正所谓物级必反,将表格分得过细有时并不好,因为这样需求将各表举行各种的关联,这会令查询时变得复杂,并且效率也大概降低,这些正规化的规定可以参考,在实际利用时,要按照项目的大小,必要时可以举行一些测试,以计划出更公道的表格构造.
以上是“数据库正规化和计划本领[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |