重温sqlserver 常用的七种优化存储过程的方法

重温sqlserver 常用的七种优化存储过程的方法,第1张

概述在写了近一年的文档加php之后,原先对于sql server 的一点知识确实都忘光了,这里转载一篇他人的文章,很实用的一些技巧。 1.使用SET NOCOUNT ON选项 我们使用SELECT语句时,除了返回对应的结果集外,还会返回相应的影响行数。使用SET NOCOUNT ON后,除了数据集就不会返回额外的信息了,减小网络流量。 2.使用确定的Schema 在使用表,存储过程,函数等等时,最好加

在写了近一年的文档加PHP之后,原先对于sql server 的一点知识确实都忘光了,这里转载一篇他人的文章,很实用的一些技巧。


1.使用SET NOCOUNT ON选项

我们使用SELECT语句时,除了返回对应的结果集外,还会返回相应的影响行数。使用SET NOCOUNT ON后,除了数据集就不会返回额外的信息了,减小网络流量。

2.使用确定的Schema

在使用表,存储过程,函数等等时,最好加上确定的Schema。这样可以使sql Server直接找到对应目标,避免去计划缓存中搜索。而且搜索会导致编译锁定,最终影响性能。比如select * from dbo.Testtable比select * from Testtable要好。from Testtable会在当前Schema下搜索,如果没有,再去dbo下面搜索,影响性能。而且如果你的表是csdn.Testtable的话,那么select * from Testtable会直接报找不到表的错误。所以写上具体的Schema也是一个好习惯。

3.自定义存储过程不要以sp_开头

因为以sp_开头的存储过程默认为系统存储过程,所以首先会去master库中找,然后在当前数据库找。建议使用USP_或者其他标识开头。

4.使用sp_executesql替代exec

原因在InsIDe Microsoft sql Server 2005 T-sql Programming书中的第四章Dynamic sql里面有具体描述。这里只是简单说明一下:sp_executesql可以使用参数化,从而可以重用执行计划。exec就是纯拼SQL语句。

5.少使用游标

可以参考InsIDe Microsoft sql Server 2005 T-sql Programming书中的第三章Cursors里面有具体描述。总体来说,sql是个集合语言,对于集合运算具有较高的性能,而Cursors是过程运算。比如对一个100万行的数据进行查询,游标需要读表100万次,而不使用游标只需要少量几次读取。

6.事务越短越好

sql Server支持并发 *** 作。如果事务过多过长,或是隔离级别过高,都会造成并发 *** 作的阻塞,死锁。此时现象是查询极慢,同时cup占用率极低。

7.使用try-catch来处理错误异常

sql Server 2005及以上版本提供对try-catch的支持,语法为:

begin try  
      ----your code 
end try 
begin catch 
       --error dispose 
end catch

一般情况可以将try-catch同事务结合在一起使用。

begin try 
    begin tran 
        --select 
        --update 
        --delete 
        --………… 
    commit 
end try 
begin catch 
    --if error 
    rollback 
end catch

文章出处 

SQL Server 优化存储过程的七种方法。 总结

以上是内存溢出为你收集整理的重温sqlserver 常用的七种优化存储过程的方法全部内容,希望文章能够帮你解决重温sqlserver 常用的七种优化存储过程的方法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1175154.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存