项目小结之数据库设计

项目小结之数据库设计

ID:24936561

大小:98.01 KB

页数:4页

时间:2018-11-17

项目小结之数据库设计_第1页
项目小结之数据库设计_第2页
项目小结之数据库设计_第3页
项目小结之数据库设计_第4页
资源描述:

《项目小结之数据库设计》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、[收藏此页][打印][推荐][评论]项目小结之数据库设计责任编辑:晓熊作者:ITPUB论坛  2009-04-09  文本Tag:系统设计数据库项目管理实例  【IT168案例】  最近做了一个小项目完整的数据库设计,想总结一些设计上的所得,希望大家多多指教。  有时一个项目,普通程序员一般不会去接触数据库设计,一般都有专业的DBA或是老程序员去设计,下面是我推测的几点可能原因:  1:新手对项目了解不深,正好这是老鸟的长处。  2:新手对局部的关注往往大于整体,很难考虑的特别周全。  3:数据库设计的好坏在某种程度

2、上直接影响项目的复杂度以及性能。  第一:我们要知道什么是范式,为什么说到数据库设计总要提到一个名词:范式。范式:符合某一种级别的关系模式的集合。设计数据库必须遵循一定的规则,在关系数据库中,这种规则就是范式。  第二:范式的分类。关系数据库中的关系必须满足一定的要求,目前关系数据库有六种范式:第一范式、第二范式、第三范式、第四范式、第五范式和第六范式。满足最低要求的是第一范式,其余范式以次类推。这么多的分类并不一定要求全部满足,平时我们通常是达到第三范式就行。  第三:范式的作用?  1:优点:是将其转化为一些表的

3、过程,这种方法可以使从数据库得到的结果更加明确。  2:缺点:可能使数据库产生重复数据,从而导致创建多余的表。  3:是在识别数据库中的数据元素、关系,以及定义所需的表和各表中的项目这些初始工作之后的一个细化的过程。  4:设计范式是数据库设计所需要满足的规范,满足这些规范的数据库是简洁的、结构明晰的,也不会发生插入、删除和更新操作异常。反之则给编程人员制造麻烦,可能存储了大量不需要的冗余信息。  下面来简单介绍下前三种范式:  一:第一范式。是对关系模式的基本要求,不满足第一范式的数据库就不是关系数据库。所谓第一范

4、是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值或者不能有重复的属性。如果出现重复的属性,就可能需要定义一个新的实体,新的实体由重复的属性构成,新实体与原实体之间为一对多关系。这个单一属性由基本类型构成,包括整型、实数、字符型、逻辑型、日期型等。例如有一张存储文件的表,正确应该是这样:可以看到这个表包含了好几个列,如果我们把这些信息都放在一列里面那么就不满足上面定义的1NF了。createtableRegulations(  ID                  i

5、nt                  identity,  Title                nvarchar(200)        null,  FileAddress          varchar(255)        null,  OpenDate            datetime            null,  TypeID              int                  null,  PostDate            datetime          

6、  null,  constraintPK_REGULATIONSprimarykey(ID))  二:第二范式:在第一范式的基础上建立起来的。要求数据库表中的每个实例或行必须可以被惟一地区分。通常需要为表加上一个列,以存储各个实例的惟一标识。这个惟一属性列被称为主关键字或主键、主码。像上面的Regulations的ID列就是一个身份标识列(identity)。  三:第三范式:要求一个数据库表中不包含已在其它表中已包含的非主关键字信息。例如:上面有了一个文件表Regulations,如果这个表是存储的主文件,它相应

7、的还有n个附件信息的话,我们就需要创建另外一张附件表来存储附件。两表如何联系起来呢,我们可以把主文件表的主键随同附件信息做为一条记录插入到附件表中,这里插入的主文件表信息中只包含了主键ID,并没有插入其它信息,这种关系就满足了第三范式要求。createtableAttachment(  ID                  int                  identity,  FileID              int                  null,//主文件主键ID  Address 

8、             varchar(255)        null,  Title                nvarchar(200)        null,  constraintPK_ATTACHMENTprimarykey(ID))   最后来总结了我这个项目中的具体应用:  第一:启用数据字典理念来提高开发效率。什么是数

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。