`

数据库的设计原则与开发技巧

阅读更多

 

随着计算机技术越来越广泛地应用于国民经济的各个领域,在计算机硬件不断微型化的同时,应用系统向着复杂化、大型化的方向发展。数据库是整个系统的核心,它的设计直接关系系统执行的效率和系统的稳定性。因此在软件系统开发中,数据库设计应遵循必要的数据库范式理论,以减少冗余、保证数据的完整性与正确性。只有在合适的数据库产品上设计出合理的数据库模型,才能降低整个系统的编程和维护难度,提高系统的实际运行效率。虽然对于小项目或中等规模的项目开发人员可以很容易地利用范式理论设计出一套符合要求的数据库,但对于一个包含大型数据库的软件项目,就必须有一套完整的设计原则与技巧。

一、成立数据小组
大型数据库数据元素多,在设计上有必要成立专门的数据小组。由于数据库设计者不一定是使用者,对系统设计中的数据元素不可能考虑周全,数据库设计出来后,往往难以找到所需的库表,因此数据小组最好由熟悉业务的项目骨干组成。
数据小组的职能并非是设计数据库,而是通过需求分析,在参考其他相似系统的基础上,提取系统的基本数据元素,担负对数据库的审核。审核内容包括审核新的数据库元素是否完全、能否实现全部业务需求;对旧数据库(如果存在旧系统)的分析及数据转换;数据库设计的审核、控制及必要调整。

二、设计原则

1.规范命名。所有的库名、表名、域名必须遵循统一的命名规则,并进行必要说明,以方便设计、维护、查询。
2.控制字段的引用。在设计时,可以选择适当的数据库设计管理工具,以方便开发人员的分布式设计和数据小组的集中审核管理。采用统一的命名规则,如果设计的字段已经存在,可直接引用;否则,应重新设计。
3.库表重复控制。在设计过程中,如果发现大部分字段都已存在,开发人员应怀疑所设计的库表是否已存在。通过对字段所在库表及相应设计人员的查询,可以确认库表是否确实重复。
4.并发控制。设计中应进行并发控制,即对于同一个库表,在同一时间只有一个人有控制权,其他人只能进行查询。
5.必要的讨论。数据库设计完成后,数据小组应与相关人员进行讨论,通过讨论来熟悉数据库,从而对设计中存在的问题进行控制或从中获取数据库设计的必要信息。
6.数据小组的审核。库表的定版、修改最终都要通过数据小组的审核,以保证符合必要的要求。
7.头文件处理。每次数据修改后,数据小组要对相应的头文件进行修改(可由管理软件自动完成),并通知相关的开发人员,以便进行相应的程序修改。

三、设计技巧

1.分类拆分数据量大的表。对于经常使用的表(如某些参数表或代码对照表),由于其使用频率很高,要尽量减少表中的记录数量。例如,银行的户主账表原来设计成一张表,虽然可以方便程序的设计与维护,但经过分析发现,由于数据量太大,会影响数据的迅速定位。如果将户主账表分别设计为活期户主账、定期户主账及对公户主账等,则可以大大提高查询效率。

 
2.索引设计。对于大的数据库表,合理的索引能够提高整个数据库的操作效率。在索引设计中,索引字段应挑选重复值较少的字段;在对建有复合索引的字段进行检索时,应注意按照复合索引字段建立的顺序进行。例如,如果对一个5万多条记录的流水表以日期和流水号为序建立复合索引,由于在该表中日期的重复值接近整个表的记录数,用流水号进行查询所用的时间接近3秒;而如果以流水号为索引字段建立索引进行相同的查询,所用时间不到1秒。因此在大型数据库设计中,只有进行合理的索引字段选择,才能有效提高整个数据库的操作效率。

3.数据操作的优化。在大型数据库中,如何提高数据操作效率值得关注。例如,每在数据库流水表中增加一笔业务,就必须从流水控制表中取出流水号,并将其流水号的数值加一。正常情况下,单笔操作的反应速度尚属正常,但当用它进行批量业务处理时,速度会明显减慢。经过分析发现,每次对流水控制表中的流水号数值加一时都要锁定该表,而该表却是整个系统操作的核心,有可能在操作时被其他进程锁定,因而使整个事务操作速度变慢。对这一问题的解决的办法是,根据批量业务的总笔数批量申请流水号,并对流水控制表进行一次更新,即可提高批量业务处理的速度。另一个例子是对插表的优化。对于大批量的业务处理,如果在插入数据库表时用普通的Insert语句,速度会很慢。其原因在于,每次插表都要进行一次I/O操作,花费较长的时间。改进后,可以用Put语句等缓冲区形式等满页后再进行I/O操作,从而提高效率。对大的数据库表进行删除时,一般会直接用Delete语句,这个语句虽然可以进行小表操作,但对大表却会因带来大事务而导致删除速度很慢甚至失败。解决的方法是去掉事务,但更有效的办法是先进行Drop操作再进行重建。
 
4.数据库参数的调整。数据库参数的调整是一个经验不断积累的过程,应由有经验的系统管理员完成。以Informix数据库为例,记录锁的数目太少会造成锁表的失败;逻辑日志的文件数目太少会造成插入大表失败等,这些问题都应根据实际情况进行必要的调整。
 
5.必要的工具。在整个数据库的开发与设计过程中,可以先开发一些小的应用工具,如自动生成库表的头文件、插入数据的初始化、数据插入的函数封装、错误跟踪或自动显示等,以此提高数据库的设计与开发效率。
 
6.避免长事务。对单个大表的删除或插入操作会带来大事务,解决的办法是对参数进行调整,也可以在插入时对文件进行分割。对于一个由一系列小事务顺序操作共同构成的长事务(如银行交易系统的日终交易),可以由一系列操作完成整个事务,但其缺点是有可能因整个事务太大而使不能完成,或者,由于偶然的意外而使事务重做所需的时间太长。较好的解决方法是,把整个事务分解成几个较小的事务,再由应用程序控制整个系统的流程。这样,如果其中某个事务不成功,则只需重做该事务,因而既可节约时间,又可避免长事务。
 
7.适当超前。计算机技术发展日新月异,数据库的设计必须具有一定前瞻性,不但要满足当前的应用要求,还要考虑未来的业务发展,同时必须有利于扩展或增加应用系统的处理功能。

 相对于中小型数据库,大型数据库的设计与开发要复杂得多,因此在设计、开发过程中,除了要遵循数据库范式理论、增加系统的一致性和完整性外,还要在总体上根据具体情况进行分布式设计,紧紧把握集中控制、统一审核的基本原则,保证数据库设计结构紧凑、分布平衡、定位迅速。在数据库操作上,要采用一定的技巧提高整个应用系统的执行效率,并注意适当超前,以适应不断变化的应用及系统发展的要求。

转载:http://blog.csdn.net/hejinzhuo/archive/2009/07/31/4395824.aspx

分享到:
评论

相关推荐

    大型数据库的设计原则与开发技巧

    【大型数据库的设计原则与开发技巧】 在当今信息化社会,数据库已成为支撑各类系统运行的核心部分,尤其是在大型系统中,数据库的设计质量直接影响着系统的性能和稳定性。本文将深入探讨大型数据库的设计原则与开发...

    大型数据库的设计原则与开发技巧.doc

    大型数据库的设计原则与开发技巧

    详细讲解大型数据库的设计原则与开发技巧

    大型数据库设计原则与开发技巧是软件系统开发中的核心环节,因为它对系统的效率和稳定性有着直接影响。数据库设计必须遵循数据库范式理论,以避免数据冗余、确保数据的完整性和正确性。随着计算机技术的普及,系统变...

    大型数据库开发技巧与原则

    【大型数据库开发技巧与原则】 在当今信息化社会,数据库已成为支撑各类系统运行的关键部分,尤其在大型系统中,数据库的设计质量直接影响着系统的性能和稳定性。本文将探讨大型数据库开发的一些核心原则和实用技巧...

    专题:全面解析数据库的设计原则与开发技巧.doc

    本文将深入探讨数据库设计的原则和开发技巧,旨在帮助开发者优化数据库架构,提升系统性能。 首先,数据库设计的经验之一是慎用游标。游标虽然能实现对数据集的逐行操作,但在处理大量数据时可能会导致性能下降甚至...

    数据库设计的原则与技巧.pdf

    数据库设计的原则与技巧 数据库设计是企业信息的核心,其应用水平的高低直接影响到企业管理水平。选择了一个高性能的数据库产品不等于就有一个好的数据库应用系统,如果数据库系统设计不合理,不仅会增加客户端和...

    SQL数据库设计的各种小技巧

    根据给定的信息,我们可以总结出以下关于SQL数据库...以上六个小技巧涵盖了从基本的设计原则到具体的技术实现,旨在帮助读者更好地理解和掌握SQL数据库设计的核心要素。希望这些内容能够在实际工作中为大家带来帮助。

    数据库设计在网站开发的应用.doc

    【数据库设计在网站开发的应用】 随着互联网的普及和发展,网站已成为现代社会不可或缺的一部分,极大地便利了人们的生活。...因此,对于程序员来说,掌握优秀的数据库设计技巧对于提升网站开发质量至关重要。

    数据库设计60个技巧

    在设计数据库表时,需关注字段的选择与设计,避免常见的陷阱,如数据类型不匹配、字段冗余等。合理规划表结构,确保数据的一致性和完整性,同时考虑到查询效率,选择适当的索引策略。 ### 选择键与索引 键的选择...

    浅谈数据库设计技巧经验

    根据“3分技术,7分经验”的原则,本文将通过分析不同水平的数据库设计者的特点,探讨数据库设计中的技巧与经验。 #### 二、数据库设计者的分类及特点 1. **未系统学习数据结构的程序员**:这类程序员设计的数据库...

    数据库设计规范及设计技巧研究.docx

    数据库设计规范及设计技巧是构建高效稳定数据库的关键。在信息技术高速发展的今天,数据库已经成为各种应用程序的基础,直接影响到程序的性能、扩展性和维护性。本文主要围绕数据库设计规范和设计技巧展开,旨在为...

    SQL SERVER 2012数据库设计与实现

    它是《SQL Server 2008数据库设计与实现》的更新版本,旨在帮助读者掌握在SQL Server 2012环境下进行高效、可靠且优化的数据库设计与实施的技巧。 本书涵盖了以下核心知识点: 1. **SQL Server 2012新特性**:介绍...

    《数据库设计与开发》.rar

    《数据库设计与开发》这本书是IT教育领域中关于数据库理论与实践的重要参考资料,它涵盖了数据库系统的基础知识、设计原则以及开发技巧。通过学习这本书,读者可以深入理解数据库的核心概念,掌握如何有效地创建、...

    软件开发,数据库设计注意事项

    数据库设计注意事项是许多IT专业人士在长期的数据库分析与设计实践中逐步总结出来的宝贵经验。对于这些经验的应用,我们不能生搬硬套、死记硬背,而应该消化理解,并结合实际情况灵活运用。在实际工作中,我们应该...

    数据库设计方法规范技巧

    在“源码帝国”这个压缩包中,可能包含了实际的Java代码示例,用于展示如何在程序中实现上述数据库设计原则和技巧。通过学习这些实例,开发者可以更好地理解如何在实际开发中应用理论知识。 总的来说,掌握数据库...

    JAVA数据库设计14个技巧

    以下是从标题“JAVA数据库设计14个技巧”及其描述、部分文本中提炼出的关键知识点,旨在提升数据库性能与管理效率。 ### 1. 理解实体间的一对一、一对多和多对多关系 在数据库设计中,实体间的关联是一大核心概念...

    Java数据库设计中的14个技巧

    ### Java数据库设计中的14个技巧 ...这些技巧不仅适用于Java开发环境,也广泛适用于其他类型的数据库设计工作中。通过掌握并应用这些技巧,可以有效提升数据库的设计水平,为构建高性能、高可用的系统奠定坚实的基础。

    数据库设计方法、规范与技巧(Word版).rar_word_数据库设计

    数据库设计是信息系统开发的核心环节,它涉及到数据的...通过深入学习《数据库设计方法、规范与技巧(Word版)》,读者可以系统地掌握这一领域的知识,并在实践中运用这些原则和技巧,设计出高效、健壮的数据库系统。

    SQL Server 2008数据库设计与实现

    整体而言,《SQL Server 2008数据库设计与实现》不仅为读者提供了丰富的理论知识,而且通过大量实践案例和技巧,帮助数据库开发者深入理解关系型数据库的设计原则,有效地实现和管理SQL Server 2008数据库系统。...

Global site tag (gtag.js) - Google Analytics