中培伟业IT资讯频道
您现在的位置:首页 > IT资讯 > 数据库 > SQL Server数据库设计优化应注意的10个问题

SQL Server数据库设计优化应注意的10个问题

2017-01-19 14:59:57 | 来源:中培企业IT培训网

SQL Server 数据库作为目前在社会上受到广泛应用的一款数据库,其设计优化是该领域的重大技术课题。中培伟业《SQL Server 2014数据库管理与性能调优》培训专家臧老师在这里就SQL Server 数据库设计优化应注意的相关问题进行了详细介绍。

1、不要使用游标。

使用游标不仅占用内存,而且还用不可思议的方式锁定表,它们可以使DBA所能做的一切性能优化等于没做。游标里每执行一次fetch就等于执行一次select。

2、创建适当的索引

每当为一个表添加一个索引,select会更快,可insert和delete却大大变慢,因为创建了维护索引需要许多额外的工作。

1)采用函数处理的字段不能利用索引

2)条件内包括了多个本表的字段运算时不能进行索引

3、使用事务

对于一些耗时的操作,使用事务可以达到很好的优化效果。

4、小心死锁

按照一定的次序来访问你的表。如果你先锁住表A,再锁住表B,那么在所有的存储过程中都要按照这个顺序来锁定它们。 如果某个存储过程先锁定表B,再锁定表A,这可能会导致一个死锁。

5、不要打开大的数据集

6、不要使用服务器端游标

与服务器端游标比起来,客户端游标可以减少服务器和网络的系统开销,并且还减少锁定时间。

7、不要忽略同时修改同一记录的问题

有时候,两个用户会同时修改同一记录,这样,后一个修改者修改了前一个修改者的操作,某些更新就会丢失。处理这种情况,创建一个timestamp字段,在写入前检查它,如果允许,就合并修改,如果存在冲突,提示用户。

8、尽量不要使用text数据类型

除非使用text处理一个很大的数据,否则不要使用它。因为它不易于查询,速度慢,用的不好还会浪费大量的空间。一般varchar可以更好的处理数据。

9、避免在索引列上使用计算  

where子句中,如果索引列是函数的一部分,优化器将不使用索引而使用全表扫描。

10、不同类型的索引效能是不一样的

应尽可能先使用效能高的数字类型的索引查找效率高于字符串类型,定长字符串char、nchar的索引效率高于变长字符串varchar、nvarchar的索引。

标签: SQL Server