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

          軟件下載吧

          當(dāng)前位置:軟件下載吧 > 數(shù)據(jù)庫 > MS_SQL > SQL開發(fā)知識(shí):SQL Server執(zhí)行動(dòng)態(tài)SQL的正確方法

          SQL開發(fā)知識(shí):SQL Server執(zhí)行動(dòng)態(tài)SQL的正確方法

          時(shí)間:2024-03-26 14:33作者:下載吧人氣:42

          SQL Server執(zhí)行動(dòng)態(tài)SQL的話,應(yīng)該如何實(shí)現(xiàn)呢?下面就為您介紹SQL Server執(zhí)行動(dòng)態(tài)SQL兩種正確方式,希望可以讓您對(duì)SQL Server執(zhí)行動(dòng)態(tài)SQL有更深的了解

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

            動(dòng)態(tài)SQL可以通過EXECUTE 或SP_EXECUTESQL這兩種方式來執(zhí)行.

            EXECUTE

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

            SP_EXECUTESQL

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

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

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

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

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

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

            SP_EXECUTESQL N’SELECT * FROM Groups’; –執(zhí)行成功

            SP_EXECUTESQL ‘SELECT * FROM Groups’ –執(zhí)行出錯(cuò)

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

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

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

            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 括號(hào)里面只能是字符串變量、字符串常量、或它們的連接組合,不能調(diào)用其它一些函數(shù)、存儲(chǔ)過程等. 如果要使用,則使用變量組合,如上所示.

            DECLARE @Sql VARCHAR(200);

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

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

            –PRINT @Sql;EXECUTE(@Sql); –出錯(cuò):必須聲明標(biāo)量變量 “@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

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

            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:動(dòng)態(tài)批處理不能訪問定義在批處理里的局部變量 . SP_EXECUTESQL 可以有輸入輸出參數(shù),比EXECUTE靈活.

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

            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的執(zhí)行效率

            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 生成了三個(gè)獨(dú)立的 ad hoc 執(zhí)行計(jì)劃,而用SP_EXECUTESQL只生成了一次執(zhí)行計(jì)劃,重復(fù)使用了三次,試想如果一個(gè)庫里面,有許多這樣類似的動(dòng)態(tài)SQL,而且頻繁執(zhí)行,如果采用SP_EXECUTESQL就能提高性能.

          以下是其他網(wǎng)友的補(bǔ)充

          有些特殊原因,我們需要在SQL語句或者存儲(chǔ)過程中動(dòng)態(tài)創(chuàng)建SQL語句,然后在SQL語句或存儲(chǔ)過程中動(dòng)態(tài)來執(zhí)行。

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

          Execute函數(shù)

          執(zhí)行方式為
          Execute(@sql)來動(dòng)態(tài)執(zhí)行一個(gè)SQL語句,但是這里的SQL語句無法得到里面的返回結(jié)果,下面來介紹另一種方法

          使用存儲(chǔ)過程 sp_ExecuteSql

          使用該存儲(chǔ)過程,則可將動(dòng)態(tài)語句中的參數(shù)返回來。

          比如

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

          標(biāo)簽MSSQL,SQLServer,技術(shù)文檔,數(shù)據(jù)庫,SQLSERVER

          相關(guān)下載

          查看所有評(píng)論+

          網(wǎng)友評(píng)論

          網(wǎng)友
          您的評(píng)論需要經(jīng)過審核才能顯示

          熱門閱覽

          最新排行

          公眾號(hào)

          主站蜘蛛池模板: 免费无码毛片一区二区APP| 一区二区免费视频| 国产一区在线mmai| 日本成人一区二区| 伊人久久精品无码麻豆一区| 亚洲欧美日韩一区二区三区 | 日韩在线视频不卡一区二区三区| 夜夜精品视频一区二区| 无码精品人妻一区| 国产一区二区在线观看| 国产免费一区二区三区不卡| 无码人妻一区二区三区免费手机| 老湿机一区午夜精品免费福利| 无码aⅴ精品一区二区三区浪潮| 色婷婷亚洲一区二区三区| 亚洲国产精品第一区二区| 无码人妻精品一区二区蜜桃百度 | 日本一区频道在线视频| 中文字幕一区二区人妻性色| 国产伦精品一区二区三区免费迷| 在线中文字幕一区| 亚洲AV日韩AV天堂一区二区三区| 国产精品无码不卡一区二区三区| 日本国产一区二区三区在线观看 | 国产一区二区电影| 一区二区三区精品高清视频免费在线播放 | 欧美亚洲精品一区二区| 精品熟人妻一区二区三区四区不卡 | 无码人妻AⅤ一区二区三区水密桃 无码欧精品亚洲日韩一区夜夜嗨 无码毛片一区二区三区中文字幕 无码毛片一区二区三区视频免费播放 | 日本一区二区三区精品视频| 2018高清国产一区二区三区| 日本伊人精品一区二区三区| 亚洲美女视频一区二区三区| 无码国产精品一区二区免费虚拟VR| 亚洲色大成网站www永久一区| 无码午夜人妻一区二区三区不卡视频| 色狠狠色噜噜Av天堂一区| 亚洲综合无码AV一区二区| 少妇激情av一区二区| 成人精品一区二区三区电影| 一区二区3区免费视频|