日韩小视频-日韩久久一区二区三区-日韩久久一级毛片-日韩久久久精品中文字幕-国产精品亚洲精品影院-国产精品亚洲欧美云霸高清

下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當前位置:軟件下載吧 > 數據庫 > MS_SQL > SQL開發知識:SQL Server執行動態SQL的正確方法

SQL開發知識:SQL Server執行動態SQL的正確方法

時間:2024-03-26 14:33作者:下載吧人氣:40

SQL Server執行動態SQL的話,應該如何實現呢?下面就為您介紹SQL Server執行動態SQL兩種正確方式,希望可以讓您對SQL Server執行動態SQL有更深的了解

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

  動態SQL可以通過EXECUTE 或SP_EXECUTESQL這兩種方式來執行.

  EXECUTE

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

  SP_EXECUTESQL

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

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

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

  下面我們來對比看看EXECUTE 和SP_EXECUTESQL的一些細節地方.

  EXECUTE(N’SELECT * FROM Groups’) –執行成功

  EXECUTE(‘SELECT * FROM Groups’) –執行成功

  SP_EXECUTESQL N’SELECT * FROM Groups’; –執行成功

  SP_EXECUTESQL ‘SELECT * FROM Groups’ –執行出錯

  Summary:EXECUTE 可以執行非Unicode或Unicode類型的字符串常量、變量.而SP_EXECUTESQL只能執行Unicode或可以隱式轉換為ntext的字符串常量、變量.

  DECLARE @GroupName VARCHAR(50);SET@GroupName =’SuperAdmin’;

  EXECUTE(‘SELECT * FROM Groups WHERE GroupName=”’ + SUBSTRING(@GroupName, 1,5) + ””); –‘SUBSTRING’ 附近有語法錯誤.

  DECLARE @Sql VARCHAR(200);

  DECLARE @GroupName VARCHAR(50);SET@GroupName =’SuperAdmin’;

  SET@Sql=’SELECT * FROM Groups WHERE GroupName=”’ + SUBSTRING(@GroupName, 1,5) + ””

  –PRINT @Sql;EXECUTE(@Sql);

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

  DECLARE @Sql VARCHAR(200);

  DECLARE @GroupName VARCHAR(50);SET@GroupName =’SuperAdmin’;

  SET@Sql=’SELECT * FROM Groups WHEREGroupName=@GroupName’

  –PRINT @Sql;EXECUTE(@Sql); –出錯:必須聲明標量變量 “@GroupName”.SET@Sql=’SELECT * FROM Groups WHERE GroupName=’ + QUOTENAME(@GroupName, ””)

  EXECUTE(@Sql); –正確:

  DECLARE @Sql NVARCHAR(200);

  DECLARE @GroupName NVARCHAR(50);SET@GroupName =’SuperAdmin’;

  SET@Sql=’SELECT * FROM Groups WHEREGroupName=@GroupName’

  PRINT @Sql;

  EXEC SP_EXECUTESQL @Sql,N’@GroupNameNVARCHAR’,@GroupName

  查詢出來沒有結果,沒有聲明參數長度.

  DECLARE @Sql NVARCHAR(200);

  DECLARE @GroupName NVARCHAR(50);SET@GroupName =’SuperAdmin’;

  SET@Sql =’SELECT * FROM Groups WHERE GroupName=@GroupName’

  PRINT @Sql;

  EXEC SP_EXECUTESQL @Sql, N’@GroupName NVARCHAR(50)’,@GroupName

  Summary:動態批處理不能訪問定義在批處理里的局部變量 . SP_EXECUTESQL 可以有輸入輸出參數,比EXECUTE靈活.

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

  DBCC FREEPROCCACHE;

  DECLARE @Sql VARCHAR(200);

  DECLARE @GroupName VARCHAR(50);SET@GroupName =’SuperAdmin’; –‘CommonUser’, ‘CommonAdmin’

  SET@Sql =’SELECT * FROM Groups WHERE GroupName=’ + QUOTENAME(@GroupName, ””)

  EXECUTE(@Sql); SELECTcacheobjtype, objtype, usecounts, sql

  FROM sys.syscacheobjects

  WHERE sql NOTLIKE ‘%cache%’

  ANDsql NOTLIKE ‘%sys.%’;

  依葫蘆畫瓢,接著我們看看SP_EXECUTESQL的執行效率

  DBCC FREEPROCCACHE;

  DECLARE @Sql NVARCHAR(200);

  DECLARE @GroupName NVARCHAR(50);SET@GroupName =’SuperAdmin’; –‘CommonUser’, ‘CommonAdmin’

  SET@Sql =’SELECT * FROM Groups WHERE GroupName=@GroupName’

  EXECUTESP_EXECUTESQL @Sql, N’@GroupName NVARCHAR(50)’, @GroupName;

  SELECTcacheobjtype, objtype, usecounts, sql

  FROM sys.syscacheobjects

  WHERE sql NOTLIKE ‘%cache%’

  ANDsql NOTLIKE ‘%sys.%’;

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

以下是其他網友的補充

有些特殊原因,我們需要在SQL語句或者存儲過程中動態創建SQL語句,然后在SQL語句或存儲過程中動態來執行。

這里,微軟提供了兩個方法,一個是使用

Execute函數

執行方式為
Execute(@sql)來動態執行一個SQL語句,但是這里的SQL語句無法得到里面的返回結果,下面來介紹另一種方法

使用存儲過程 sp_ExecuteSql

使用該存儲過程,則可將動態語句中的參數返回來。

比如

declare @sql nvarchar(800),@dd varchar(20)
set @sql=’set @mm=”測試字符串”’
exec sp_executesql @sql,N’@mm varchar(20) output’,@dd output
select @dd

標簽MSSQL,SQLServer,技術文檔,數據庫,SQLSERVER

相關下載

查看所有評論+

網友評論

網友
您的評論需要經過審核才能顯示

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 97在线视频免费公开观看 | 国产精品国产三级国产普通 | 成人永久免费视频网站在线观看 | 亚洲欧美成人综合在线 | 大臿蕉香蕉大视频成人 | 国产区香蕉精品系列在线观看不卡 | 日本欧美中文 | 亚洲精品国产成人一区二区 | 日韩成人免费在线视频 | 亚洲日本一区二区三区高清在线 | 欧美一级片网站 | 亚洲资源在线 | 久久伊人精品热在75 | 久久综合色播 | 日韩精品一区二区三区四区 | 久久久一区二区三区不卡 | 性刺激免费视频观看在线观看 | 激情6月丁香婷婷色综合 | 精品久久久久久国产免费了 | 国内精品小视频在线 | 精品久久久久久影院免费 | 国产欧美日韩综合精品无毒 | 亚洲视频一区在线观看 | a级毛片免费看 | 伊人色综合久久天天人手人停 | 午夜性爽视频男人的天堂在线 | 全免费a级毛片免费看 | 日本一级在线播放线观看视频 | 久久综合久久自在自线精品自 | 国产三级国产精品国产国在线观看 | 亚洲欧美精品一中文字幕 | 国产激情一区二区三区在线观看 | 欧美一区二区在线观看免费网站 | 免费一级淫片aaa片毛片a级 | 国产精品不卡无毒在线观看 | 国产一区二区三区在线免费观看 | 欧美一级高清片在线 | 伊人成人在线 | 日韩精品欧美国产精品亚 | 黄色三级国产 | 国产一级内谢a级高清毛片 国产一级片毛片 |