SQL Server数据库优化的10多种方法

巧妙优化sql server数据库的几种方法,在实际操作中导致查询速度慢的原因有很多,其中最为常见有以下的几种:没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷)。

  I/O吞吐量小,形成了瓶颈效应。

  没有创建计算列导致查询不优化SQL Server数据库。

  内存不足。

  网络速度慢。

  查询出的数据量过大(可以采用多次查询,其他的方法降低数据量)。

  锁或者死锁(这也是查询慢最常见的问题,是程序设计的缺陷)。

  sp_lock,sp_who,活动的用户查看,原因是读写竞争资源。

  返回了不必要的行和列。

  查询语句不好,没有优化。

  可以通过如下方法来优化查询 :

  1、把数据、日志、索引放到不同的I/O设备上,增加读取速度,以前可以将Tempdb应放在RAID0上,SQL2000不在支持。数据量(尺寸)越大,提高I/O越重要。

  2、纵向、横向分割表,减少表的尺寸(sp_spaceuse)。

  3、升级硬件。

  4、根据查询条件,建立索引,优化索引、优化SQL Server数据库访问方式,限制结果集的数据量。注意填充因子要适当(最好是使用默认值0)。索引应该尽量小,使用字节数小的列建索引好(参照索引的创建),不要对有限的几个值的字段建单一索引如性别字段。

  5、提高网速。

  6、扩大服务器的内存,Windows 2000和SQL server 2000能支持4-8G的内存。配置虚拟内存: 虚拟内存大小应基于计算机上并发运行的服务进行配置。运行 Microsoft SQL Server? 2000 时,可考虑将虚拟内存大小设置为计算机中安装的物理内存的 1.5 倍。如果另外安装了全文检索功能,并打算运行 Microsoft 搜索服务以便执行全文索引和查询,可考虑:

  将虚拟内存大小配置为至少是计算机中安装的物理内存的 3 倍。将 SQL Server max server memory 服务器配置选项配置为物理内存的 1.5 倍(虚拟内存大小设置的一半)。

  7、增加服务器 CPU个数;但是必须明白并行处理串行处理更需要资源例如内存。使用并行还是串行程是MsSQL自动评估选择的。单个任务分解成多个任务,就可以在处理器 上运行。例如耽搁查询的排序、连接、扫描和GROUP BY字句同时执行,SQL SERVER根据系统的负载情况决定最优的并行等级,复杂的需要消耗大量的CPU的查询最适合并行处理。但是更新操作Update,Insert, Delete还不能并行处理。

  8、如果是使用like进行查询的话,简单的使用index是不行的,但是全文索引,耗空间。 like ‘a%’ 使用索引 like ‘%a’ 不使用索引用 like ‘%a%’ 查询时,查询耗时和字段值总长度成正比,所以不能用CHAR类型,而是VARCHAR。对于字段的值很长的建全文索引。

  9、DB Server 和APPLication Server 分离;OLTP和OLAP分离。

  10、分布式分区视图可用于实现数据库服务器联合体。联合体是一组分开管理的服务器,但它们相互协作分担系统的处理负荷。这种通过分区数据形成 数据库服务器联合体的机制能够扩大一组服务器,以支持大型的多层 Web 站点的处理需要。有关更多信息,参见设计联合数据库服务器。(参照SQL帮助文件’分区视图’)在实现分区视图之前,必须先水平分区表。

  在创建成员表后,在每个成员服务器上定义一个分布式分区视图,并且每个视图具有相同的名称。这样,引用分布式分区视图名的查询可以在任何一个成 员服务器上运行。系统操作如同每个成员服务器上都有一个原始表的复本一样,但其实每个服务器上只有一个成员表和一个分布式分区视图。数据的位置对应用程序 是透明的。

  11、重建索引 DBCC REINDEX ,DBCC INDEXDEFRAG,收缩数据和日志 DBCC SHRINKDB,DBCC SHRINKFILE. 设置自动收缩日志.对于大的数据库不要设置数据库自动增长,它会降低服务器的性能。在T-sql的写法上有很大的讲究,下面列出常见的要点:首 先,DBMS处理查询计划的过程是这样的:

  查询语句的词法、语法检查。

  将语句提交给DBMS的查询优化器。

  优化器做代数优化和存取路径的优化SQL Server数据库。

  由预编译模块生成查询规划。

  然后在合适的时间提交给系统处理执行。

  最后将执行结果返回给用户其次,看一下SQL SERVER的数据存放的结构:一个页面的大小为8K(8060)字节,8个页面为一个盘区,按照B树存放。

  12、Commit和rollback的区别 Rollback:回滚所有的事物。 Commit:提交当前的事物. 没有必要在动态SQL里写事物,如果要写请写在外面如: begin tran exec(@s) commit trans 或者将动态SQL 写成函数或者存储过程。[SPAN]

  13、在查询Select语句中用Where字句限制返回的行数,避免表扫描,如果返回不必要的数据,浪费了服务器的I/O资源,加重了网络的负担降低性能。如果表很大,在表扫描的期间将表锁住,禁止其他的联接访问表,后果严重。

时间: 2024-10-01 03:31:42

SQL Server数据库优化的10多种方法的相关文章

SQL Server数据库优化实战(一)

前言:一直想写一些关于SQL Server 数据库优化的文章,不过介于本人能力有限,一直不敢班门弄斧. 如今,想把已经整理好的几章放在博客上和大家分享,与君共勉. 分析问题: 对于优化来说,准确的找到问题点才是重中之重.接下来的几章会重点介绍如何去准确的发现问题,并迅速的提出最有效的解决方案. 获得问题关键点的方式方法会有很多,虽说自己动手丰衣足食,但最直接的就是听客户或者提出者的需求,并详细的询问需求. 例如:某个查询慢,某个操作慢等:当然更高端的就是直接告诉您哪条语句慢(一般来说能确定到语句

转 : SQL Server数据库优化经验总结

优化数据库的注意事项: 1.关键字段建立索引. 2.使用存储过程,它使SQL变得更加灵活和高效. 3.备份数据库和清除垃圾数据. 4.SQL语句语法的优化.(可以用Sybase的SQL Expert,可惜我没找到unexpired的序列号) 5.清理删除日志. SQL语句优化的基本原则: 1.使用索引来更快地遍历表. 缺省情况下建立的索引是非群集索引,但有时它并不是最佳的.在非群集索引下,数据在物理上随机存放在数据页上.合理的索引设计要建立在对各种查询的 分析和预测上.一般来说:①.有大量重复值

Windows 2008服务器环境PHP连接SQL Server数据库的配置及连接方法

背景: PHP程序常用的数据库是Mysql数据库,但是由于实际项目需要,要求PHP网站连接SQL Server数据库查询一些必要信息.因此,本文就来给大家介绍一下如何安装及配置PHP扩展,可以实现PHP利用PDO函数连接SQL Server数据库. 正文: 要让PHP配置支持sql server,需要安装一些必要软件及扩展,步骤如下: 1.在微软官方页面https://www.microsoft.com/en-us/download/details.aspx?id=20098下载PHP扩展压缩包

SQL Server数据库优化实战(三)

前言: 本章主要来介绍一下收缩日志和表的压缩. 收缩日志文件 --利用 exec sp_spaceused 语句查看数据库大小 --右键数据库属性 --查看选项 --将恢复模式设置成简单 --右键数据库-任务-收缩-文件 --文件类型选择日志 --查看收缩后数据库大小 --右键数据库属性-选项 --将恢复模式设置成完整 --注意:此时需要进行一次数据库完整备份 表压缩 --SQL Server 2005及以上版本支持表分区 表分区具体操作详见以下网址: http://blog.csdn.net/

SQL Server数据库优化实战(二)

前言: 本章主要介绍一下SQL Server Profiler(事件探查器),通过探查器,来分析语句运行的效果. --SQL Server Profiler ['pr??fa?l?(r)] 事件探查器 SQL Profiler是一个图形界面和一组系统存储过程,其作用如下: -图形化监视SQL Server查询: -在后台收集查询信息: -分析性能: -诊断像死锁之类的问题: -调试T-SQL语句: -模拟重放SQL Server活动: -也可以使用SQL Profiler捕捉在SQL Serve

SQL Server 数据库优化剖析

一.SQL Profiler 事件类 Stored Procedures\RPC:Completed TSQL\SQL:BatchCompleted 事件关键字段 EventSequence.EventClass.SPID.DatabaseName.Error.StartTime.TextData. HostName.ClientProcessID.ApplicationName. CPU.Reads.Writes.Duration.RowCounts 1.跟踪慢SQL 2.跟踪SQL执行错误

sql server 数据库表误删除的恢复方法

由于意外操作,在企业管理器里误删除了数据库的表,那么误删除了表数据怎么办呢? 很多人的一贯做法是先从日志恢复,如果从日志恢复不行就从mdf文件本身恢复. 那么误删除数据后,最先要做的是先分离数据库,停止数据库服务,吧mdf和ldf复制出来. 从mdf文件恢复数据早在几年前就应用到客户数据库,但是从mdf恢复数据有一定的局限性,mdf文件很容易被其他表的记录覆盖掉删除的记录,,就会出现从mdf恢复数据出现数据不完整或者出现数据重复的现象. 为了更好的服务客户,我们开发了两种工具,一种是用mdf进行

MS Sql Server 数据库或表修复

提示数据库处于恢复模式时重建日志文件可以解决 DBCC REBUILD_LOG('db_name','c:\mssql7\data\dbxxx_3.LDF') MS Sql Server 提供了很多数据库修复的命令,当数据库质疑或是有的无法完成读取时可以尝试这些修复命令. 1. DBCC CHECKDB  重启服务器后,在没有进行任何操作的情况下,在SQL查询分析器中执行以下SQL进行数据库的修复,修复数据库存在的一致性错误与分配错误. use master declare @databasen

MS Sql Server 数据库或表修复(DBCC CHECKDB)

MS Sql Server 提供了很多数据库修复的命令,当数据库质疑或是有的无法完成读取时可以尝试这些修复命令.  1. DBCC CHECKDB  重启服务器后,在没有进行任何操作的情况下,在SQL查询分析器中执行以下SQL进行数据库的修复,修复数据库存在的一致性错误与分配错误. use master declare @databasename varchar(255) set @databasename='需要修复的数据库实体的名称' exec sp_dboption @databasena