日韩欧美国产精品免费一二-日韩欧美国产精品亚洲二区-日韩欧美国产精品专区-日韩欧美国产另-日韩欧美国产免费看-日韩欧美国产免费看清风阁

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

詳解SQL Server中的動態(tài)SQL概念

admin
2011年5月4日 15:10 本文熱度 2991

動態(tài)SQL:code that is executed dynamically。它一般是根據(jù)用戶輸入或外部條件動態(tài)組合的SQL語句塊。動態(tài)SQL能靈活的發(fā)揮SQL強大的功能、方便的解決一些其它方法難以解決的問題。相信使用過動態(tài)SQL的人都能體會到它帶來的便利,然而動態(tài)SQL有時候在執(zhí)行性能(效率)上面不如靜態(tài)SQL,而且使用不恰當,往往會在安全方面存在隱患(SQL 注入式攻擊)。


動態(tài)SQL可以通過EXECUTE 或SP_EXECUTESQL這兩種方式來執(zhí)行。(來自MSDN)


EXECUTE 執(zhí)行 Transact-SQL 批中的命令字符串、字符串或執(zhí)行下列模塊之一:系統(tǒng)存儲過程、用戶定義存儲過程、標量值用戶定義函數(shù)或擴展存儲過程。SQL Server 2005 擴展了 EXECUTE 語句,以使其可用于向鏈接服務器發(fā)送傳遞命令。此外,還可以顯式設(shè)置執(zhí)行字符串或命令的上下文


SP_EXECUTESQL


執(zhí)行可以多次重復使用或動態(tài)生成的 Transact-SQL 語句或批處理。Transact-SQL 語句或批處理可以包含嵌入?yún)?shù)。在批處理、名稱作用域和數(shù)據(jù)庫上下文方面,SP_EXECUTESQL 與 EXECUTE 的行為相同。SP_EXECUTESQL stmt 參數(shù)中的 Transact-SQL 語句或批處理在執(zhí)行 SP_EXECUTESQL 語句時才編譯。隨后,將編譯 stmt 中的內(nèi)容,并將其作為執(zhí)行計劃運行。該執(zhí)行計劃獨立于名為 SP_EXECUTESQL 的批處理的執(zhí)行計劃。SP_EXECUTESQL 批處理不能引用調(diào)用 SP_EXECUTESQL 的批處理中聲明的變量。SP_EXECUTESQL 批處理中的本地游標或變量對調(diào)用 SP_EXECUTESQL 的批處理是不可見的。對數(shù)據(jù)庫上下文所作的更改只在 SP_EXECUTESQL 語句結(jié)束前有效。


如果只更改了語句中的參數(shù)值,則 sp_executesql 可用來代替存儲過程多次執(zhí)行 Transact-SQL 語句。因為 Transact-SQL 語句本身保持不變,僅參數(shù)值發(fā)生變化,所以 SQL Server 查詢優(yōu)化器可能重復使用首次執(zhí)行時所生成的執(zhí)行計劃。


一般來說,我們推薦、優(yōu)先使用SP_EXECUTESQL來執(zhí)行動態(tài)SQL,一方面它更加靈活、可以有輸入輸出參數(shù)、另外一方面,查詢優(yōu)化器更有可能重復使用執(zhí)行計劃,提高執(zhí)行效率。還有就是使用SP_EXECUTESQL能提高安全性;當然也不是說要完全擯棄EXECUTE,在特定場合下,EXECUTE比SP_EXECUTESQL更方便些,比如動態(tài)SQL字符串是VARCHAR類型、不是NVARCHAR類型。SP_EXECUTESQL 只能執(zhí)行是Unicode的字符串或是可以隱式轉(zhuǎn)換為ntext的常量或變量、而EXECUTE則兩種類型的字符串都能執(zhí)行。


下面我們來對比看看EXECUTE 和SP_EXECUTESQL的一些細節(jié)地方。

  1. EXECUTE (N'SELECT * FROM Groups')      --執(zhí)行成功  
  2. EXECUTE ('SELECT * FROM Groups')       --執(zhí)行成功  
  3.  
  4. SP_EXECUTESQL N'SELECT * FROM Groups'--執(zhí)行成功  
  5. SP_EXECUTESQL 'SELECT * FROM Groups'   --執(zhí)行出錯 

Summary:EXECUTE 可以執(zhí)行非Unicode或Unicode類型的字符串常量、變量。而SP_EXECUTESQL只能執(zhí)行Unicode或可以隱式轉(zhuǎn)換為ntext的字符串常量、變量。

  1. DECLARE @GroupName VARCHAR(50);  
  2. SET @GroupName = 'SuperAdmin';  
  3. EXECUTE ('SELECT * FROM Groups WHERE 
  4. GroupName=''' + SUBSTRING(@GroupName, 1,5) + ''''); --'SUBSTRING' 附近有語法錯誤。  
  5. DECLARE @Sql VARCHAR(200);  
  6. DECLARE @GroupName VARCHAR(50);  
  7. SET @GroupName = 'SuperAdmin';  
  8. SET @Sql = 'SELECT * FROM Groups 
  9. WHERE GroupName=''' + SUBSTRING(@GroupName, 1,5) + '''' 
  10. --PRINT @Sql;  
  11. EXECUTE (@Sql); 

Summary:EXECUTE 括號里面只能是字符串變量、字符串常量、或它們的連接組合,不能調(diào)用其它一些函數(shù)、存儲過程等。 如果要使用,則使用變量組合,如上所示。

  1. DECLARE @Sql VARCHAR(200);  
  2. DECLARE @GroupName VARCHAR(50);  
  3. SET @GroupName = 'SuperAdmin';  
  4. SET @Sql = 'SELECT * FROM Groups WHERE GroupName=@GroupName' 
  5. --PRINT @Sql;  
  6. EXECUTE (@Sql);  --出錯:必須聲明標量變量 "@GroupName"。  
  7. SET @Sql = 'SELECT * 
  8. FROM Groups WHERE GroupName=' + QUOTENAME(@GroupName, '''')  
  9. EXECUTE (@Sql);  --正確:  
  10. DECLARE @Sql NVARCHAR(200);  
  11. DECLARE @GroupName NVARCHAR(50);  
  12. SET @GroupName = 'SuperAdmin';  
  13. SET @Sql = 'SELECT * FROM Groups WHERE GroupName=@GroupName' 
  14. PRINT @Sql;  
  15. EXEC SP_EXECUTESQL @Sql, N'@GroupName NVARCHAR',@GroupName  

查詢出來沒有結(jié)果,沒有聲明參數(shù)長度。

  1. DECLARE @Sql NVARCHAR(200);  
  2. DECLARE @GroupName NVARCHAR(50);  
  3. SET @GroupName = 'SuperAdmin';  
  4. SET @Sql = 'SELECT * FROM Groups WHERE GroupName=@GroupName' 
  5. PRINT @Sql;  
  6. EXEC SP_EXECUTESQL @Sql, N'@GroupName NVARCHAR(50)',@GroupName  

Summary:動態(tài)批處理不能訪問定義在批處理里的局部變量 。 SP_EXECUTESQL 可以有輸入輸出參數(shù),比EXECUTE靈活。


下面我們來看看EXECUTE , SP_EXECUTESQL的執(zhí)行效率,首先把緩存清除執(zhí)行計劃,然后改變用@GroupName值SuperAdmin、CommonUser、CommonAdmin分別執(zhí)行三次。然后看看其使用緩存的信息

  1. DBCC FREEPROCCACHE;   
  2.  
  3. DECLARE @Sql VARCHAR(200);  
  4. DECLARE @GroupName VARCHAR(50);  
  5. SET @GroupName = 'SuperAdmin'--'CommonUser', 'CommonAdmin'  
  6. SET @Sql = 'SELECT * 
  7. FROM Groups WHERE GroupName=' + QUOTENAME(@GroupName, '''')  
  8. EXECUTE (@Sql);   
  9. SELECT cacheobjtype, objtype, usecounts, sql  
  10. FROM sys.syscacheobjects  
  11. WHERE sql NOT LIKE '%cache%' 
  12.   AND sql NOT LIKE '%sys.%'

如下圖所示



依葫蘆畫瓢,接著我們看看SP_EXECUTESQL的執(zhí)行效率.

  1. DBCC FREEPROCCACHE;   
  2. DECLARE @Sql NVARCHAR(200);  
  3. DECLARE @GroupName NVARCHAR(50);  
  4. SET @GroupName = 'SuperAdmin'--'CommonUser', 'CommonAdmin'  
  5. SET @Sql = 'SELECT * FROM Groups WHERE GroupName=@GroupName' 
  6. EXECUTE SP_EXECUTESQL @Sql, N'@GroupName NVARCHAR(50)', @GroupName;   
  7. SELECT cacheobjtype, objtype, usecounts, sql  
  8. FROM sys.syscacheobjects  
  9. WHERE sql NOT LIKE '%cache%' 
  10.   AND sql NOT LIKE '%sys.%'

執(zhí)行結(jié)果如下圖所示:



Summary:EXEC 生成了三個獨立的 ad hoc 執(zhí)行計劃,而用SP_EXECUTESQL只生成了一次執(zhí)行計劃,重復使用了三次,試想如果一個庫里面,有許多這樣類似的動態(tài)SQL,而且頻繁執(zhí)行,如果采用SP_EXECUTESQL就能提高性能。 


該文章在 2011/5/4 15:10:21 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調(diào)度、堆場、車隊、財務費用、相關(guān)報表等業(yè)務管理,結(jié)合碼頭的業(yè)務特點,圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 97国产在线看片免费人成视频 | 91大神精品在线观看 | 精品国产自在现线免费观看 | 99精产国品一二三产区区 | 亚洲欧美日韩国产一区二区三区 | 国产偷v | 国产精品白丝 | 亚洲香蕉中文日韩v日本 | 人人草人人 | 欧美一级特黄高清视频 | 亚洲精品乱拍国产一区二区三区 | 亚洲欧美日韩综合第一页 | 欧美国产精品免费观看 | 欧美高清性色生活片免费观看 | 国产精品视频高清在线播放 | 欧美校园激情清纯另类 | 91九色蝌蚪在线 | 国产精选视频 | 两个人高清在线观 | 男人花免费观看视频在线观看 | 国产福利自产拍在线观看 | 国产一区二区三区欧美亚洲 | 日国产一区三区三区在线观看 | 亚洲制服在线日韩 | 国产亚洲高清不卡在线观看 | 日韩免费的视频在线观看香蕉 | 日韩一区二区三区在线精品 | 日本素人黑人视频 | 国产亚洲一区二区三区在线 | 亚洲熟女乱综合一区二区 | 一区②区三区电影网 | 尤物视频在线免费观看 | 日韩在线视频不卡一区二区三 | 中文字幕第一页在线 | 精品中文高清欧 | 精品熟女乱伦一区二区三 | 欧美人与动性行为网站免费 | 一区二区三区在线看 | 2048国产精品原创综合在线 | 国产秘精品入口免费软件 | 一区二区日韩 |