当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 解决SQL速度慢的方法

MSSQL
sql server的保留关键字
SQL2000 关于 Java JDBC 驱动的安装和设定
SQL Server2005数据库查询中使用CTE
如何整理SQL Server输入数据
SQL优化34条
怎样用SQL服务器调节器收集重要信息
黑客经验谈 MSSQLSA权限入侵的感悟
SQL Server企业管理器和查询分析器简介
SQL Server开发人员应聘常被问的问题
限制系统管理员对SQL Server进行访问
升级到SQL Server 2005之后转换登录
SQL Server 2000中监控失败的登录尝试
MSSQL移动到新服务器出现不匹配问题
让你见识一下SQL Server口令的脆弱性
全面调整SQL Server的硬件性能计划
SQL SERVER数据导成INSERT
SQL Server中保护数据的安全选项
防范SQL注入攻击的新办法
SQL Server数据库安全管理机制详解
妙用SQL子查询来从子表里删除数据

MSSQL 中的 解决SQL速度慢的方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 56 ::
收藏到网摘: n/a

  下面是我多年经验的总结: 网络编程总要和数据库打交道。和数据库打交道总要接触到SQL。如何使你的SQL 跑得快一点,本文介绍几种行之有效的方法: 方法一、尽量使用复杂的SQL来代替简单的一堆SQL. 同样的事务,一个复杂的SQL完成的效率高于一堆简单SQL完成的效率。有多个查询时,要善于使用JOIN。 oRs=objDBC.Execute(‘SELECT * FROM Books‘) for(; !oRs.Eof; oRs.MoveNext()) { oRs2=objDBC.Execute(‘SELECT * FROM Authors WHERE AuthorID=‘‘+oRs (‘AuthorID‘).value+‘‘‘); Response.write(oRs(‘Title‘).value+‘ ‘+oRs2(‘Name‘)+‘<br>‘); } 要比下面的代码慢: oRs=objDBC.Execute(‘SELECT Books.Title,Authors.Name FROM Books JOIN Authors ON Authors.AuthorID=Books.AuthorID‘); for(; !oRs.Eof; oRs.MoveNext()) { Response.write(oRs(‘Title‘).value+‘ ‘+oRs(‘Name‘)+‘<br>‘); } 方法二、尽量避免使用可更新Recordset oRs=objDBC.Execute(‘SELECT * FROM Authors WHERE AuthorID=17‘,(some flags)); oRs(‘Name‘)=‘Karl Karlsson‘; oRs.Update(); 要比下面的代码慢: objDBC.Execute(‘UPDATE Authors SET Name=‘Karl Karlsson‘ WHERE AuthorID=17‘); 方法三、更新数据库时,尽量采用批处理更新将所有的SQL组成一个大的批处理SQL,并一次运行;这比一个一个地更新数据要有效率得多。这样也更加满足你进行事务处理的需要: (in JScript) strSQL=‘‘; strSQL+=‘SET XACT_ABORT ON\n‘; strSQL+=‘BEGIN TRANSACTION\n‘; strSQL+=‘INSERT INTO Orders(OrdID,CustID,OrdDat) VALUES(‘9999‘, ‘1234‘,GETDATE())\n‘; strSQL+=‘INSERT INTO OrderRows(OrdID,OrdRow,Item,Qty) VALUES(‘9999 ‘,‘01‘,‘G4385‘,5)\n‘; strSQL+=‘INSERT INTO OrderRows(OrdID,OrdRow,Item,Qty) VALUES(‘9999 ‘,‘02‘,‘G4726‘,1)\n‘; strSQL+=‘COMMIT TRANSACTION\n‘; strSQL+=‘SET XACT_ABORT OFF\n‘; objDBC.Execute(strSQL); 其中,SET XACT_ABORT OFF 语句告诉SQL Server,如果下面的事务处理过程中,如果遇到错误,就取消已经完成的事务。 方法四、数据库索引 方法五、避免使Text字段太大当字符串的值大小不固定时,用varchar比用char的效果要好些。我曾经看到一个例子程序,字段被定义为TEXT(255),但是他的取值经常只有20个字符。这个数据表有50k个记录,从而使这个数据库很大,大的数据库必然较慢。