数据库设计经验之谈..docVIP

  1. 1、本文档共14页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据库设计经验之谈.

一个成功的管理系统,是由:[50%?的业务?+ 50%?的软件]?所组成,而?50%?的成功软件又有?[25%?的数据库?+ 25%?的程序]?所组成,数据库设计的好坏是一个关键。如果把企业的数据比做生命所必需的血液,那么数据库的设计就是应用中最重要的一部分。有关数据库设计的材料汗牛充栋,大学学位课程里也有专门的讲述。不过,就如我们反复强调的那样,再好的老师也比不过经验的教诲。所以我归纳历年来所走的弯路及体会,并在网上找了些对数据库设计颇有造诣的专业人士给大家传授一些设计数据库的技巧和经验。精选了其中的?60?个最佳技巧,并把这些技巧编写成了本文,为了方便索引其内容划分为?5?个部分: ? 第?1?部分?-?设计数据库之前 这一部分罗列了?12?个基本技巧,包括命名规范和明确业务需求等。 第?2?部分?-?设计数据库表 总共?24?个指南性技巧,涵盖表内字段设计以及应该避免的常见问题等。 第?3?部分?-?选择键 怎么选择键呢?这里有?10?个技巧专门涉及系统生成的主键的正确用法,还有何?时以及如何索引字段以获得最佳性能等。 第?4?部分?-?保证数据完整性 讨论如何保持数据库的清晰和健壮,如何把有害数据降低到最小程度。 第?5?部分?-?各种小技巧 不包括在以上?4?个部分中的其他技巧,五花八门,有了它们希望你的数据库开发工作会更轻松一些。 第?1?部分?-?设计数据库之前 考察现有环境 在设计一个新数据库时,你不但应该仔细研究业务需求而且还要考察现有的系统。大多数数据库项目都不是从头开始建立的;通常,机构内总会存在用来满足特定需求的现有系统(可能没有实现自动计算)。显然,现有系统并不完美,否则你就不必再建立新系统了。但是对旧系统的研究可以让你发现一些可能会忽略的细微问题。一般来说,考察现有系统对你绝对有好处。 定义标准的对象命名规范 一定要定义数据库对象的命名规范。对数据库表来说,从项目一开始就要确定表名是采用复数还是单数形式。此外还要给表的别名定义简单规则(比方说,如果表名是一个单词,别名就取单词的前?4?个字母;如果表名是两个单词,就各取两个单词的前两个字母组成?4?个字母长的别名;如果表的名字由?3?个单词组成,你不妨从头两个单词中各取一个然后从最后一个单词中再取出两个字母,结果还是组成?4?字母长的别名,其余依次类推)对工作用表来说,表名可以加上前缀?WORK_?后面附上采用该表的应用程序的名字。表内的列[字段]要针对键采用一整套设计规则。比如,如果键是数字类型,你可以用?_N?作为后缀;如果是字符类型则可以采用?_C?后缀。对列[字段]名应该采用标准的前缀和后缀。再如,假如你的表里有好多“money”字段,你不妨给每个列[字段]增加一个?_M?后缀。还有,日期列[字段]最好以?D_?作为名字打头。 ? 检查表名、报表名和查询名之间的命名规范。你可能会很快就被这些不同的数据库要素的名称搞糊涂了。假如你坚持统一地命名这些数据库的不同组成部分,至少你应该在这些对象名字的开头用?Table、Query?或者?Report?等前缀加以区别。 ? 如果采用了?Microsoft Access,你可以用?qry、rpt、tbl?和?mod?等符号来标识对象(比如?tbl_Employees)。我在和?SQL Server?打交道的时候还用过?tbl?来索引表,但我用sp_company?(现在用?sp_feft_)标识存储过程,因为在有的时候如果我发现了更好的处理办法往往会保存好几个拷贝。我在实现?SQL Server 2000?时用?udf_?(或者类似的标记)标识我编写的函数。 工欲善其事,?必先利其器 采用理想的数据库设计工具,比如:SyBase?公司的?PowerDesign,她支持PB、VB、Delphe?等语言,通过?ODBC?可以连接市面上流行的?30?多个数据库,包括dBase、FoxPro、VFP、SQL Server?等,今后有机会我将着重介绍?PowerDesign?的使用。 获取数据模式资源手册 正在寻求示例模式的人可以阅读《数据模式资源手册》一书,该书由?Len Silverston、W. H. Inmon?和?Kent Graziano?编写,是一本值得拥有的最佳数据建模图书。该书包括的章节涵盖多种数据领域,比如人员、机构和工作效能等。其他的你还可以参考:[1]萨师煊 王珊著 数据库系统概论(第二版)高等教育出版社?1991、[2][美] Steven M.Bobrowski?著?Oracle 7?与客户/服务器计算技术从入门到精通 刘建元等译 电子工业出版社,1996、[3]周中元 信息系统建模方法(下) 电子与信息化 1999年第3期,1999 畅想未来,但不可忘了过去的教训 我发现询问用户如何

文档评论(0)

stzs + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档