亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

分享一下SQL Server執(zhí)行動態(tài)SQL的正確方式

2024-08-31 01:04:57
字體:
供稿:網(wǎng)友

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

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

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

  EXECUTE

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

  SP_EXECUTESQL

  執(zhí)行可以多次重復(fù)使用或動態(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í)行計劃運(yùn)行.該執(zhí)行計劃獨立于名為 SP_EXECUTESQL 的批處理的執(zhí)行計劃.SP_EXECUTESQL 批處理不能引用調(diào)用 SP_EXECUTESQL 的批處理中聲明的變量.SP_EXECUTESQL 批處理中的本地游標(biāo)或變量對調(diào)用 SP_EXECUTESQL 的批處理是不可見的.對數(shù)據(jù)庫上下文所作的更改只在 SP_EXECUTESQL 語句結(jié)束前有效.

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

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

  下面我們來對比看看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í)行出錯

  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' 附近有語法錯誤.

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

  DECLARE @Sql VARCHAR(200);

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

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

  --PRINT @Sql;EXECUTE(@Sql); --出錯:必須聲明標(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:動態(tài)批處理不能訪問定義在批處理里的局部變量 . SP_EXECUTESQL 可以有輸入輸出參數(shù),比EXECUTE靈活.

  下面我們來看看EXECUTE , SP_EXECUTESQL的執(zhí)行效率,首先把緩存清除執(zhí)行計劃,然后改變用@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 生成了三個獨立的 ad hoc 執(zhí)行計劃,而用SP_EXECUTESQL只生成了一次執(zhí)行計劃,重復(fù)使用了三次,試想如果一個庫里面,有許多這樣類似的動態(tài)SQL,而且頻繁執(zhí)行,如果采用SP_EXECUTESQL就能提高性能.

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

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

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

Execute函數(shù)

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

使用存儲過程 sp_ExecuteSql

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

比如

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

執(zhí)行他就會將內(nèi)部創(chuàng)建的SQL語句的某個變量的值返回到外部調(diào)用者。

主要來源于工作中的一個偶然需要:

create proc proc_InToServer @收費(fèi)站點編號 varchar(4),@車道號 tinyint,@進(jìn)入時間 varchar(23),@UID char(16),@車牌 varchar(12),@車型 char(1),@識別車牌號 varchar(12),@識別車型 char(1),@收費(fèi)金額 money,@交易狀態(tài) char(1),@有圖像 bit,@離開時間 varchar(23),@速度 float,@HasInsert int outputasbegin  declare @inTime datetime,@TableName varchar(255),@leaveTime datetime,@HasTable bit,@Sql nvarchar(4000) select @intime=Convert(datetime,@進(jìn)入時間),@leaveTime=Convert(datetime,@離開時間) set @TableName='ETC03_01_OBE原始過車記錄表_'+dbo.formatDatetime(@intime,'YYYYMMDD') select @HasTable=(Case when Count(*)>0 then 1 else 0 end) from sysobjects where id=Object_id(@TableName) and ObjectProperty(id,'IsUserTable')=1 if @HasTable=0 begin  set @Sql='CREATE TABLE [dbo].['+@TableName+'] ( [收費(fèi)站點編號] [char] (4) COLLATE Chinese_PRC_CI_AS NOT NULL, [車道號] [tinyint] NOT NULL, [進(jìn)入時間] [datetime] NOT NULL, [UID] [char] (16) COLLATE Chinese_PRC_CI_AS NOT NULL, [車牌] [varchar] (12) COLLATE Chinese_PRC_CI_AS NULL , [車型] [char] (1) COLLATE Chinese_PRC_CI_AS NULL , [識別車牌號] [varchar] (12) COLLATE Chinese_PRC_CI_AS NULL , [識別車型] [char] (1) COLLATE Chinese_PRC_CI_AS NULL , [收費(fèi)金額] [money] NULL , [交易狀態(tài)] [char] (1) COLLATE Chinese_PRC_CI_AS NULL , [有圖像] [bit] NOT NULL , [離開時間] [datetime] NULL , [速度] [float] NULL,    Constraint'+' PK_'+@TableName+' primary key(收費(fèi)站點編號,車道號,進(jìn)入時間,UID)    ) ON [PRIMARY]'   Execute(@Sql)  end   set @sql = 'select @Cnt=count(*) from '+@TableName+ ' where 收費(fèi)站點編號='''+@收費(fèi)站點編號+''' and 車道號='+cast(@車道號 as varchar(4))+' and 進(jìn)入時間='''+@進(jìn)入時間+''' and UID='''+@UID+''''  set @sql = @sql + ' if @Cnt=0 '    set @sql=@sql+'insert '+@TableName+' values('''+@收費(fèi)站點編號+''','+cast(@車道號 as varchar(4))+','''+@進(jìn)入時間+''','''+@Uid+''','''+@車牌+    ''','''+@車型+''','''+  @識別車牌號+''','''+@識別車型+''','+Cast(@收費(fèi)金額 as varchar(8))+','''+@交易狀態(tài)+''','+cast(@有圖像 as varchar(1))+  ','''+@離開時間+''','+Cast(@速度 as varchar(8))+')'  --Execute(@sql)   exec sp_executesql @sql,N'@Cnt int output',@HasInsert outputend

補(bǔ)充資料二、

SQL Server循環(huán)執(zhí)行動態(tài)SQL語句.

使用Navicate工具執(zhí)行查詢成功。

declare @name nvarchar(100)declare @sql nvarchar(200)declare @i intset @i =10000while @i<=99999begin	set @name = 'test' + cast(@i as varchar(20))	set @sql =N'SELECT * INTO '+ @name +' FROM test'	exec sp_executesql @sql	print @name set @i=@i + 1end

以上就是VeVb武林網(wǎng)小編為大家整理的SQL Server執(zhí)行動態(tài)SQL的正確方式,希望可以幫助到大家。


注:相關(guān)教程知識閱讀請移步到MSSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
正在播放一区二区三区| 成人三级视频在线观看| 国产成人亚洲综合a∨婷婷图片| 麻豆精品国产传媒| 天天综合网天天综合| аⅴ天堂中文在线网| 综合 欧美 亚洲日本| jizzjizz国产精品喷水| 欧美午夜精品免费| www.中文字幕.com| 日本成年免费网站| 丰满少妇一区二区三区| 国产精品久久久久久久久| 2020国产精品| 国外成人在线视频网站| 色综合手机在线| 天天色av.com| 亚洲国产欧美一区二区三区丁香婷| 99免费在线观看视频| 十九岁完整版在线观看好看云免费| 日韩不卡视频在线| 欧美精品一区二区久久| 久久综合图片| 亚洲日本va午夜在线电影| 国产精品一级伦理| 亚洲国产精品久久久| 91精品国产成人www| 欧美人体做爰大胆视频| 日韩专区中文字幕| 日本不卡不卡| 少妇无码一区二区三区| 国产探花在线免费观看| 久久婷婷国产综合精品青草| 99产精品成人啪免费网站| 色先锋aa成人| 九九爱免费视频在线观看| 欧美激情va永久在线播放| 四季av一区二区| 色综合一区二区| 亚洲精品一区二区网址| 亚洲最大成人av| 欧美一区二区三区系列电影| 每日更新av在线播放| 亚洲最大成人网色| 中国美女黄色一级片| 欧美黑人巨大精品一区二区| 欧美精品日韩一区| 日韩中文字幕在线不卡| 亚洲国产日韩在线| 久青草国产97香蕉在线视频| 蜜乳av一区二区三区| 波多野结衣视频免费观看| 久久久久亚洲精品一区二区三区| 欧美日韩国产经典色站一区二区三区| 国产精品黄色在线观看| 国产乱妇无码大片在线观看| 午夜国产精品影院在线观看| 亚洲精品电影久久久| 亚洲免费电影在线| 91九色蝌蚪国产| 国产精品亚洲激情| 久久综合久久鬼色| 黄色一级视频在线观看| 白天操夜夜操| 国产丝袜不卡| 国产成人啪精品午夜在线观看| 亚洲福利视频专区| 久久丫精品忘忧草西安产品| 亚洲成人av免费观看| 国产又爽又黄的视频| 日本亚洲欧洲无免费码在线| 日本在线播放一区二区| 妞干网在线免费视频| 国产精品一区二区三区在线| 奇米精品一区二区三区在线观看| 91精品国产色综合久久不卡蜜臀| 欧美日韩精品一区二区在线播放| 91精品成人| 日本18视频网站| 5566先锋影音夜色资源站在线观看| 337p亚洲精品色噜噜狠狠| 日韩中文在线中文网三级| 国产不卡在线观看| 亚洲国产成人精品久久| 中文字幕一区二区三区域| 国产又黄又猛视频| 91激情在线观看| 国产aⅴ2021| 国产网站一区二区| 免费在线观看av片| 欧美在线观看视频网站| 国产精品羞羞答答在线| 色噜噜久久综合| 性生生活大片免费看视频| 久久精品日产第一区二区三区高清版| 高清av一区二区三区| 在线播放亚洲一区| 538国产精品视频一区二区| 亚洲精品成人区在线观看| 国产精品中文久久久久久久| 非洲一级黄色片| 97久久精品一区二区三区的观看方式| 中文字幕一区二区三区乱码| 午夜激情视频网| 日韩黄色在线| 日韩精品视频网站| 99热在线观看| 日韩欧美不卡视频| 亚洲精品在线影院| 国产亚洲一区二区在线观看| 99精品视频在线观看播放| 99re6在线精品视频免费播放| 91蝌蚪视频在线| 欧美日韩久久不卡| 亚洲国产精品久久久久婷婷软件| 欧美中文在线免费| 精品蜜桃在线看| 久久亚洲AV无码专区成人国产| 国产成人无码精品久久久性色| www.亚洲自拍| 人妻体内射精一区二区三区| 成人精品福利| 欧美精品一区二区三区免费| 亚洲香蕉中文网| 国产精品久久久久久久妇| 国产成人免费xxxxxxxx| 国产一级大片| 欧美日韩综合在线免费观看| 性高湖久久久久久久久| 91av亚洲| 亚洲综合网在线观看| 国产日韩在线免费观看| 热久久99这里有精品| 情se视频网在线观看| 成人在线观看免费视频| 亚洲国产一区二区a毛片| 欧美日韩免费看| 又黄又爽又色的视频| 精品人妻无码一区二区性色| 久久亚洲私人国产精品va| 亚洲国产一二三精品无码| 不卡的av电影| 中文字幕成人免费视频| 亚州福利视频| 久久久国产欧美| 精品国产一区二区三区av片| 日本韩国在线视频爽| 爱草在线视频| 成人毛片视频免费看| bt欧美亚洲午夜电影天堂| 精品日韩视频| 538国产精品一区二区在线| 国产精品99蜜臀久久不卡二区| 精品久久国产97色综合| av影片在线播放| 亚洲天堂成人网| 欧美体内谢she精2性欧美| 亚洲伊人网在线观看| 黄色成人在线免费观看| 成人午夜在线影院| 欧美成人有码| 香蕉精品久久| 久久久精品成人| 手机成人av在线| 国产精品夜色7777狼人| 亚洲人成电影网站色mp4| 深夜福利在线视频| 亚洲午夜精品久久久中文影院av| 日韩av免费电影| 亚洲色图欧美自拍| 韩国中文字幕在线| 欧美一区二区三区黄片| 波多野结衣 作品| 国产 日韩 欧美 在线| 国产激情视频网址| 狠狠躁夜夜躁久久躁别揉| 欧美一级成年大片在线观看| 母乳一区在线观看| 男人在线视频资源| 夜夜嗨av一区二区三区中文字幕| 亚洲视屏在线播放| 天堂av一区二区三区在线播放| 国产国语**毛片高清视频| 国产视频精品视频| 亚洲最大福利视频| ass极品国模人体欣赏| 欧美电影院免费观看| 日本在线天堂| 精品国产乱码久久久久久樱花| 97碰在线视频| 美女视频免费一区| 特级西西人体www高清大胆| 香蕉成人伊视频在线观看| 欧美一区高清| 黄瓜视频污在线观看| 成人短视频app| 亚洲免费成人av电影| 国产精品久久久久久久久免费丝袜| 欧美人与动牲性行为| 午夜精品久久久久久不卡8050| 国产成人精品视| 欧美在线va视频| 日韩三级成人av网| 一区在线观看| 性18欧美另类| 日韩成人三级视频| 手机在线理论电影| 日韩欧美国产综合| 在线免费观看亚洲视频| 欧美有码在线观看视频| 亚洲天堂久久久| 人人干在线观看| 日韩中文字幕在线| 久久先锋影音av| 日本一区二区三区四区五区| 成人性生交大片免费看在线播放| 久久精品这里只有精品| 国产伦精品一区二区三区视频黑人| 在线小视频网址| 在线āv视频| 日韩色av导航| 91在线视频18| 黄色片网站在线观看| 一级肉体全黄裸片| 8x8ⅹ拨牐拨牐拨牐在线观看| 亚洲欧美激情视频在线观看一区二区三区| 四虎永久在线观看| 亚洲激情不卡| 奇米影音第四色| 欧美日韩精品综合在线| 国产尤物一区二区三区| 26uuu色噜噜精品一区二区| 美女视频黄免费的久久| 欧美一区中文字幕| 黄色成人在线| 亚洲视频精选在线| 91.xxx.高清在线| 韩国av一区二区| 欧美精品91| 亚洲五码中文字幕| 欧美一区二区三区婷婷月色| 在线免费看黄色片| 成人一区二区| 欧美成人高清视频在线观看| 国产成人一区二区三区电影| 欧美做受xxxxxⅹ性视频| 在线成人免费网站| 亚洲大片在线观看| 日本综合视频| 中文字幕乱在线伦视频中文字幕乱码在线| 欧美激情图区| 欧美一级片免费看| 国产精品对白刺激| 欧美绝顶高潮抽搐喷水合集| 国自产精品手机在线观看视频| 一本色道69色精品综合久久| 天天操夜夜欢| 日韩免费看片| 激情综合五月| 精品免费二区三区三区高中清不卡| 国产高清自拍视频| 日韩精品一区二区三区第95| 黄色免费网站在线观看| 亚洲精品88| 懂色av影视一区二区三区| 国产一区二区三区黄片| 自拍偷自拍亚洲精品被多人伦好爽| 亚洲高清毛片| 热舞福利精品大尺度视频| 欧美一区二区三区久久久| 日韩a级作爱片一二三区免费观看| 精品免费视频一区二区| theporn国产在线精品| 日本欧美韩国| 污视频在线观看免费| 亚洲欧洲精品视频| 日韩欧国产精品一区综合无码| 在线永久看片免费的视频| 国产亚洲aⅴaaaaaa毛片| 综合久久给合久久狠狠狠97色| 国产精品性做久久久久久| 国产主播色在线| 日韩av中文字幕第一页| 中文字幕av一区| 国产精品丝袜一区二区| 亚洲国产精品999| 日本在线播放不卡| 亚洲人成网站在线播放2019| 触手亚洲一区二区三区| 国产精品黄视频| 黄色工厂这里只有精品| 精品小视频在线观看| 国产91精品一区二区绿帽| 日批视频免费播放| 福利视频1000| 曰本三级日本三级日本三级| 国产精品一品二品| 免费在线成人av电影| 一区二区三区在线观看www| 国产xxx在线观看| 一区高清视频| 狠狠色狠狠色综合人人| 亚洲丶国产丶欧美一区二区三区| 久久精品视频va| 国产模特精品视频久久久久| 久久国产日韩欧美| 91精品国产综合久久香蕉| 中文字幕亚洲一区二区va在线| 另类欧美小说| 国产三级电影在线播放| 久99久精品视频免费观看| 精品国产精品国产精品| 久久视频免费看| 韩日a级毛片| 色噜噜夜夜夜综合网| 亚洲香肠在线观看| 完美搭档在线观看| 激情视频免费| 中文乱码人妻一区二区三区视频| 91精品国产乱码久久| 性生大片免费观看性| 日韩欧美国产系列| 天天摸日日摸狠狠添| 欧美在线视频全部完| 日韩在线免费播放| 影音先锋中文一区| 福利一区二区三区四区| 开心色怡人综合网站|