数据库设计阶段可以说是以后整个系统性能的关键阶段,在这个阶段,几乎包含所有性能调优的过程。
在数据库设计完成后,可以进行初步的索引设计,好的索引设计可以指导编码阶段写出高效率的代码,为整个系统的性能打下良好的基础。
以下是性能要求设计阶段需要注意的:
1、 数据库逻辑设计的规范化
数据库逻辑设计的规范化就是我们一般所说的范式,我们可以这样来简单理解范式:
第1规范:没有重复的组或多值的列,这是数据库设计的最低要求。
第2规范: 每个非关键字段必须依赖于主关键字,不能依赖于一个组合式主关键字的某些组成部分。消除部分依赖,大部分情况下,数据库设计都应该达到第二范式。
第3规范: 一个非关键字段不能依赖于另一个非关键字段。消除传递依赖,达到第三范式应该是系统中大部分表的要求,除非一些特殊作用的表。
更高的范式要求这里就不再作介绍了,个人认为,如果全部达到第二范式,大部分达到第三范式,系统会产生较少的列和较多的表,因而减少了数据冗余,也利于性能的提高。
2、 合理的冗余
完全按照规范化设计的系统几乎是不可能的,除非系统特别的小,在规范化设计后,有计划地加入冗余是必要的。
冗余可以是冗余数据库、冗余表或者冗余字段,不同粒度的冗余可以起到不同的作用。
冗余可以是为了编程方便而增加,也可以是为了性能的提高而增加。从性能角度来说,冗余数据库可以分散数据库压力,冗余表可以分散数据量大的表的并发压力,也可以加快特殊查询的速度,冗余字段可以有效减少数据库表的连接,提高效率
3、 主键的设计
主键是必要的,SQL SERVER的主键同时是一个唯一索引,而且在实际应用中,我们往往选择最小的键组合作为主键,所以主键往往适合作为表的聚集索引。聚集索引对查询的影响是比较大的,这个在下面索引的叙述。
在有多个键的表,主键的选择也比较重要,一般选择总的长度小的键,小的键的比较速度快,同时小的键可以使主键的B树结构的层次更少。
主键的选择还要注意组合主键的字段次序,对于组合主键来说,不同的字段次序的主键的性能差别可能会很大,一般应该选择重复率低、单独或者组合查询可能性大的字段放在前面。
4、 外键的设计
外键作为数据库对象,很多人认为麻烦而不用,实际上,外键在大部分情况下是很有用的,理由是:
外键是最高效的一致性维护方法,数据库的一致性要求,依次可以用外键、CHECK约束、规则约束、触发器、客户端程序,一般认为,离数据越近的方法效率越高。
谨慎使用级联删除和级联更新,级联删除和级联更新作为SQL SERVER 2000当年的新功能,在2005作了保留,应该有其可用之处。我这里说的谨慎,是因为级联删除和级联更新有些突破了传统的关于外键的定义,功能有点太过强大,使用前必须确定自己已经把握好其功能范围,否则,级联删除和级联更新可能让你的数据莫名其妙的被修改或者丢失。从性能看级联删除和级联更新是比其他方法更高效的方法。
5、 字段的设计
字段是数据库最基本的单位,其设计对性能的影响是很大的。需要注意如下:
A、数据类型尽量用数字型,数字型的比较比字符型的快很多。
B、 数据类型尽量小,这里的尽量小是指在满足可以预见的未来需求的前提下的。
C、 尽量不要允许NULL,除非必要,可以用NOT NULL+DEFAULT代替。
D、少用TEXT和IMAGE,二进制字段的读写是比较慢的,而且,读取的方法也不多,大部分情况下最好不用。
E、 自增字段要慎用,不利于数据迁移。
6、 数据库物理存储和环境的设计
在设计阶段,可以对数据库的物理存储、操作系统环境、网络环境进行必要的设计,使得我们的系统在将来能适应比较多的用户并发和比较大的数据量。
这里需要注意文件组的作用,适用文件组可以有效把I/O操作分散到不同的物理硬盘,提高并发能力。
地址:http://www.cnitblog.com/ldqok/archive/2008/09/17/49149.html
分享到:
相关推荐
在SQL存储过程中,有以下几个重要的知识点: 1. **定义与创建**:存储过程可以通过`CREATE PROCEDURE`语句来创建,用户可以指定输入参数、输出参数或两者皆有,以满足不同的调用需求。例如: ```sql CREATE ...
在使用Druid与SQL Server数据库配合时,需要注意以下几点: 1. **驱动兼容性**:确保你的项目中引入了与SQL Server版本匹配的JDBC驱动,如mssql-jdbc。 2. **配置Druid**:在Spring的配置文件中,你需要定义Druid...
在设计ER图时,需要注意以下几点: 1. **实体识别**:确定系统中的主要实体,如“客户”、“产品”、“订单”等。 2. **属性定义**:为每个实体定义属性,如“客户”的属性可能包括“姓名”、“地址”、“电话”等...
根据给定的文件信息,我们可以提炼出以下几个关键的知识点,这些知识点主要围绕着数据库课程实习报告中的教务管理系统,以及其开发过程中涉及的MFC框架和SQL Server 2008数据库的应用。 ### 1. 教务管理系统的需求...
Oracle数据库课程设计报告主要涵盖了以下几个核心知识点: 1. **Oracle数据库**:Oracle是全球领先的数据库管理系统,用于存储、管理和检索数据。在本课程设计中,Oracle作为后台数据库,支持前端应用的各种操作,...
但在使用时,需要注意以下几点: 1. 目标数据库需要预先创建好对应的表结构。 2. `SELECT INTO`只复制数据,不复制源表的索引或约束。 3. 该方法适用于SQL Server的不同版本间,但不适用于不同类型的数据库。 4. ...
在实际开发过程中,还需要注意以下几点: - 进行彻底的需求分析和数据库设计阶段的工作。 - 熟悉SQL语法,特别是事务控制和锁机制。 - 持续监控数据库性能,定期进行数据库维护。 #### 四、建议与注意事项 - **...
在本次课程设计中,作者通过一系列的经历,积累了丰富的知识和经验,并分享了以下几个关键点: 1. **.NET框架与C#语言**:在导师的引导下,作者初次接触了Microsoft的.NET框架,尤其是C#语言。C#以其简洁和面向对象...
在 SQL Server 中,数据库结构由以下几部分组成: * 表(Table):用于存储数据的基本结构单元。 * 视图(View):是一种虚拟表,基于一个或多个表的数据计算而成。 * 存储过程(Stored Procedure):是一组为了...
这个系统的设计涉及到以下几个关键知识点: 1. **费用类型和业务员管理**: - 费用类型管理涉及不同的电信服务,如话费、流量费、增值服务费等,需要创建对应的费用类别并进行分类管理。 - 业务员管理则涵盖了...
数据库实验心得体会还提醒学习者在学习中需要注意以下几点:认真上好专业实验课,多在实践中锻炼自己;写程序的过程中要考虑周到,严密;在做设计的时候要有信心,有耐心,切勿浮躁;认真的学习课本知识,掌握课本中...
数据库优化是提升应用性能的关键环节,尤其是在大...综上所述,SQL优化和索引设计是数据库性能提升的重要手段。通过理解这些原则和技巧,开发人员能够更好地编写高效、稳定的SQL语句,以应对各种复杂的数据库应用场景。
现以不同管理员种类列出系统的功能点设计: 1.学生用户:登录功能、退出功能、在线选课、选课查看、下载学习资料、添加留言、查看和回复留言信息、添加作业信息、查看我的作业、学习心得的管理; 2.教师用户:登录...
包含了课程设计的各个方面,包括任务书、相关技术介绍、需求分析、概念结构设计、逻辑结构设计、数据库物理设计、数据库实施、系统测试、系统的主要功能和使用说明、课程设计心得等几个部分。 从标题和描述中,我们...
对职工信息管理系统的设计,需要考虑到以下几点: 1. 需求分析:对企业的信息化管理进行需求分析,以确定系统的功能和性能要求。 2. 概念结构设计:根据需求分析的结果,建立概念结构模型,定义实体、属性和关系。 ...
在数据库设计方面,有几点值得我们注意。首先,数据冗余曾经被视为不良实践,但在某些情况下,适度的数据冗余可以提高查询效率,减少联表操作,避免了大量的JOIN操作带来的性能影响。然而,冗余必须谨慎处理,以防止...
根据给定的文件信息,我们可以提炼出关于“人事档案管理系统”的关键知识点,涵盖需求分析、概念设计、逻辑设计、物理设计、数据脚本、触发器、存储过程等几个方面。 ### 1. 需求分析 #### 1.1 编写目的 - 目的是...
根据提供的文档信息,我们可以从中提炼出以下几个主要的知识点: ### 数据库课程设计实践的重要性 - **背景**: 随着信息技术的快速发展,数据库在现代社会中的应用越来越广泛,无论是企业还是个人,都离不开数据库...
在《数据库原理与设计》课程设计中,针对超市管理数据库的设计主要包括以下几个方面: 1. **基本信息管理**: - **超市信息管理**:包括录入、修改、查询和输出超市的基本信息,如超市代号、超市名、经理名以及...
在进行数据库课程设计时,学生需要掌握SQL语言,理解关系数据库模型,熟悉数据库设计的范式理论,以及如何利用工具如PowerDesigner进行建模。同时,良好的文档编写能力和逻辑思维能力也是必不可少的。通过这样的课程...