一个系统的性能的提升,不仅仅是试运行或者维护阶段的性能调优的任务,也不仅仅是开发阶段的事情,而是在整个软件生命周期都须要注意,进行有效工做才能达到的。因此我但愿按照软件生命周期的不一样阶段来总结数据库性能优化相关的注意事项。sql
1、分析阶段数据库
通常来讲,在系统分析阶段每每有太多须要关注的地方,系统各类功能性、可用性、可靠性、安全性需求每每吸引了咱们大部分的注意力,可是,咱们必须注意,性能是很重要的非功能性需求,必须根据系统的特色肯定其实时性需求、响应时间的需求、硬件的配置等。最好能有各类需求的量化的指标。 另外一方面,在分析阶段应该根据各类需求区分出系统的类型,大的方面,区分是OLTP(联机事务处理系统)和OLAP(联机分析处理系统)。编程
2、设计阶段缓存
设计阶段能够说是之后系统性能的关键阶段,在这个阶段,有一个关系到之后几乎全部性能调优的过程—数据库设计。 在数据库设计完成后,能够进行初步的索引设计,好的索引设计能够指导编码阶段写出高效率的代码,为整个系统的性能打下良好的基础。安全
如下是性能要求设计阶段须要注意的:性能优化
一、网络
数据库逻辑设计的规范化 数据库逻辑设计的规范化就是咱们通常所说的范式,咱们能够这样来简单理解范式:并发
第1规范:没有重复的组或多值的列,这是数据库设计的最低要求数据库设计
第2规范: 每一个非关键字段必须依赖于主关键字,不能依赖于一个组合式主关键字的某些组成部分。消除部分依赖,大部分状况下,数据库设计都应该达到第二范式。函数
第3规范: 一个非关键字段不能依赖于另外一个非关键字段。消除传递依赖,达到第三范式应该是系统中大部分表的要求,除非一些特殊做用的表。更高的范式要求这里就再也不做介绍了,我的认为,若是所有达到第二范式,大部分达到第三范式,系统会产生较少的列和较多的表,于是减小了数据冗余,也利于性能的提升。
二、
合理的冗余
彻底按照规范化设计的系统几乎是不可能的,除非系统特别的小,在规范化设计后,有计划地加入冗余是必要的。 冗余能够是冗余数据库、冗余表或者冗余字段,不一样粒度的冗余能够起到不一样的做用。 冗余能够是为了编程方便而增长,也能够是为了性能的提升而增长。从性能角度来讲,冗余数据库能够分散数据库压力,冗余表能够分散数据量大的表的并发压力,也能够加快特殊查询的速度,冗余字段能够有效减小数据库表的链接,提升效率。
3 、
主键的设计
主键是必要的,SQL SERVER的主键同时是一个惟一索引,并且在实际应用中,咱们每每选择最小的键组合做为主键,因此主键每每适合做为表的汇集索引。汇集索引对查询的影响是比较大的,这个在下面索引的叙述。 在有多个键的表,主键的选择也比较重要,通常选择总的长度小的键,小的键的比较速度快,同时小的键可使主键的B树结构的层次更少。
主键的选择还要注意组合主键的字段次序,对于组合主键来讲,不一样的字段次序的主键的性能差异可能会很大,通常应该选择重复率低、单独或者组合查询可能性大的字段放在前面。
四、
外键的设计
外键做为数据库对象,不少人认为麻烦而不用,实际上,外键在大部分状况下是颇有用的,理由是: 外键是最高效的一致性维护方法,数据库的一致性要求,依次能够用外键、CHECK约束、规则约束、触发器、客户端程序,通常认为,离数据越近的方法效率越高。
谨慎使用级联删除和级联更新,级联删除和级联更新做为SQL SERVER 2000当年的新功能,在2005做了保留,应该有其可用之处。我这里说的谨慎,是由于级联删除和级联更新有些突破了传统的关于外键的定义,功能有点太过强大,使用前必须肯定本身已经把握好其功能范围,不然,级联删除和级联更新可能让你的数据莫名其妙的被修改或者丢失。从性能看级联删除和级联更新是比其余方法更高效的方法。
五、
字段的设计
字段是数据库最基本的单位,其设计对性能的影响是很大的。须要注意以下:
A、数据类型尽可能用数字型,数字型的比较比字符型的快不少。
B、 数据类型尽可能小,这里的尽可能小是指在知足能够预见的将来需求的前提下的。
C、 尽可能不要容许NULL,除非必要,能够用NOT NULL+DEFAULT代替。
D、少用TEXT和IMAGE,二进制字段的读写是比较慢的,并且,读取的方法也很少,大部分状况下最好不用。
E、 自增字段要慎用,不利于数据迁移。
六、
数据库物理存储和环境的设计 在设计阶段,能够对数据库的物理存储、操做系统环境、网络环境进行必要的设计,使得咱们的系统在未来能适应比较多的用户并发和比较大的数据量。 这里须要注意文件组的做用,适用文件组能够有效把I/O操做分散到不一样的物理硬盘,提升并发能力。
七、
系统设计
整个系统的设计特别是系统结构设计对性能是有很大影响的,对于通常的OLTP系统,能够选择C/S结构、三层的C/S结构等,不一样的系统结构其性能的关键也有所不一样。 系统设计阶段应该概括一些业务逻辑放在数据库编程实现,数据库编程包括数据库存储过程、触发器和函数。用数据库编程实现业务逻辑的好处是减小网络流量并可更充分利用数据库的预编译和缓存功能。
八、
索引的设计
在设计阶段,能够根据功能和性能的需求进行初步的索引设计,这里须要根据预计的数据量和查询来设计索引,可能与未来实际使用的时候会有所区别。
关于索引的选择,应改主意:
A、 根据数据量决定哪些表须要增长索引,数据量小的能够只有主键。
B、 根据使用频率决定哪些字段须要创建索引,选择常常做为链接条件、筛选条件、聚合查询、排序的字段做为索引的候选字段。
C、 把常常一块儿出现的字段组合在一块儿,组成组合索引,组合索引的字段顺序与主键同样,也须要把最经常使用的字段放在前面,把重复率低的字段放在前面。
D、 一个表不要加太多索引,由于索引影响插入和更新的速度。