黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

SQL Server 優化存儲過程的七種方法

系統 2411 0
原文: SQL Server 優化存儲過程的七種方法

優化存儲過程有很多種方法,下面介紹最常用的7種。

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 優化存儲過程的七種方法


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論