国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

兩種方式令SQL Server正確執行動態SQL

數據庫 SQL Server
本文將介紹兩種正確的方法,令SQL Server執行動態SQL語句。希望可以讓您對SQL Server執行動態SQL有更深的了解。

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的一些細節地方。

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

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

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

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

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

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

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

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

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

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

如下圖所示:

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

  1. DBCC FREEPROCCACHE;  
  2. DECLARE @Sql NVARCHAR(200);  
  3. DECLARE @GroupName NVARCHAR(50);SET@GroupName ='SuperAdmin'--'CommonUser', 'CommonAdmin'  
  4. SET@Sql ='SELECT * FROM Groups WHERE GroupName=@GroupName' 
  5. EXECUTESP_EXECUTESQL @Sql, N'@GroupName NVARCHAR(50)', @GroupName;  
  6. SELECTcacheobjtype, objtype, usecounts, sql  
  7. FROM sys.syscacheobjects  
  8. WHERE sql NOTLIKE '%cache%' 
  9. ANDsql NOTLIKE '%sys.%';  

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

【編輯推薦】

  1. SQL Server使用索引實現數據訪問優化
  2. SQL Server數據庫優化經驗總結
  3. 如何使用SQLServer數據庫查詢累計值
  4. 淺析Oracle和SqlServer存儲過程的調試、出錯處理
  5. 幾段SQLServer語句和存儲過程
  6. 50種方法優化SQL Server數據庫查詢
責任編輯:彭凡 來源: IT專家網
相關推薦

2010-11-12 11:48:15

2010-10-21 16:24:18

sql server升

2024-02-04 09:24:45

MyBatisSQL語句Spring

2010-10-20 15:48:56

SQL Server許

2009-04-03 09:00:20

SQL Server2005用戶

2010-06-30 13:07:17

SQL Server函

2010-10-21 16:38:27

sql server文

2010-03-16 15:23:32

java動態載入

2010-09-02 16:28:03

SQL刪除

2010-07-05 15:12:30

SQL Server主

2011-03-03 10:26:04

Pureftpd

2011-04-06 11:05:21

SQL Server數交換數據

2009-11-13 10:20:44

2010-07-08 10:38:24

MS SQL Serv

2010-07-13 15:39:23

SQL Server

2010-11-10 13:22:41

SQL Server備

2010-09-13 13:05:03

sql server分

2010-11-09 13:09:58

SQL Server分

2023-01-30 08:41:07

MyBatisSQL語句

2010-11-12 11:44:37

SQL Server刪
點贊
收藏

51CTO技術棧公眾號

国产乱码精品一区二区三区忘忧草 | 精品国产一区二区三区麻豆小说 | 在线综合+亚洲+欧美中文字幕| 韩国毛片一区二区三区| 国产精品国产三级国产专播精品人| 日韩性xxx| 狠狠色丁香久久婷婷综| 91精品国产91久久久久青草| 日本女优一区| 日本久久久久久久久| 成人香蕉社区| 久久久免费电影| 久久午夜剧场| 国产精品网站在线| 少妇高潮喷水久久久久久久久久| 欧美sss在线视频| 亚洲精品成人悠悠色影视| 免费在线观看的av网站| 久久99蜜桃| 欧美亚洲免费电影| 国产一区二区三区不卡av| 久久久久久久久久久成人| 99精品国产一区二区三区2021 | 国产精品羞羞答答xxdd| 国产精品videossex国产高清| 国产精品一区三区| 美女扒开大腿让男人桶| 国产精品久久久久久久久久白浆| 久久在线免费视频| 亚洲国产视频二区| 97在线免费观看| 青青草国产成人a∨下载安卓| 欧美日韩国产另类不卡| 爆操欧美美女| 91网站视频在线观看| 国产精品久久久久久久电影| 欧美日韩一二三四| 99视频网站| 久久一日本道色综合久久| 在线免费观看一区二区三区| 国产99精品在线观看| 冲田杏梨av在线| 亚洲精品国产一区二区精华液| 视频午夜在线| 精品国产91洋老外米糕| 综合激情丁香| 图片区小说区国产精品视频| 日本五码在线| 精品国产免费人成在线观看| 欧美色网在线| 国产精品极品美女在线观看免费| 怡红院精品视频在线观看极品| 色综合亚洲精品激情狠狠| 精品电影在线| 亚洲国产成人久久综合一区| 国产精品一区二区美女视频免费看 | 亚洲精选中文字幕| 日本特黄a级高清免费大片| 麻豆精品久久| 欧美中文字幕一区二区三区| 久久国产亚洲精品无码| 99精品久久久| 精品一区二区三区毛片| 午夜精品av| 色乱码一区二区三在线看| 91在线一区二区| 日本中文不卡| jlzzjlzz亚洲日本少妇| 日本高清视频网站www| 日韩精品一区二区三区中文精品| 日本高清不卡中文字幕| 欧美日韩美少妇| 国产精品久久久久久久久久久久久久久| 国产精品黄视频| 国产在线看一区| 最大av网站| 国产精品美女久久久久久| 日本三日本三级少妇三级66| 国产主播精品| 欧美有码在线观看| 麻豆亚洲精品| 二区中文字幕| 亚洲国产精久久久久久久| 久久中文资源| 中文字幕日韩一区二区三区不卡| 亚洲人精品一区| 中文字幕人成乱码在线观看| 国产成人精品一区二区三区| 日本一区二区三区视频在线看| 日韩精品极品毛片系列视频| 国产黄在线看| 欧美精品在线播放| 欧美中文日韩| 小香蕉视频在线| 日韩一区在线视频| 久久久夜夜夜| 在线视频尤物| 欧美激情奇米色| 激情五月播播久久久精品| 伪装者在线观看完整版免费| 欧美激情第一页xxx| 国产美女视频91| 国产原厂视频在线观看| 国产在线一区二区三区| 精品国产1区| 欧美日韩不卡在线视频| 国产在线精品不卡| 日韩在线资源| 国产精品一区二区三区久久久| 久久女同互慰一区二区三区| jizz大全欧美jizzcom| 亚洲精品电影网| 成人福利av| 久久综合五月天| 久久er精品视频| 日韩在线资源| 国产精品手机视频| 色综合天天视频在线观看| 日本一区二区三区在线观看视频| 久久久黄色av| av一级亚洲| 我的公把我弄高潮了视频| 精品国产电影一区二区| 国产一区导航| 成人av在线不卡| 精品国偷自产国产一区| 日韩亚洲精品在线| 丁香婷婷在线| 91久色国产| 欧美性生交xxxxx久久久| 日本高清免费电影一区| 国内福利写真片视频在线| 国产97色在线|日韩| 亚洲免费在线播放| 国产欧美日韩精品高清二区综合区| 成人羞羞视频免费| 色综合av在线| 欧美日韩影院| 成人午夜电影在线观看| 亚洲精品乱码久久久久久金桔影视| 久久深夜福利| 国产理论电影在线| 手机在线视频你懂的| 国产一区二区久久精品| 91丨porny丨蝌蚪视频| 久久久久毛片免费观看| 牛夜精品久久久久久久| 日韩欧美亚洲成人| 99九九热只有国产精品| 欧洲亚洲精品视频| 狠狠色综合网站久久久久久久| 欧美日韩一区精品| 老牛影视一区二区三区| 绿色成人影院| 国产免费成人在线| 88国产精品欧美一区二区三区| 亚洲午夜在线观看视频在线| 伊人天天综合| 欧美gay囗交囗交| xxxx一级片| 国产精品一区专区欧美日韩| 欧美视频一区二区在线观看| 美女视频网站黄色亚洲| 久久69成人| 全网国产福利在线播放| 国产精品久久波多野结衣| 亚洲国产精品电影在线观看| 久久这里只有精品首页| 欧美亚洲激情| 久草成色在线| 青草热久免费精品视频| 高跟丝袜欧美一区| 日韩电影一区二区三区| 青柠在线影院观看日本| 精品国产乱码久久久久久久软件| 亚洲二区在线播放视频| 国产欧美一二三区| 欧美特黄视频| 日本美女久久| 天海翼一区二区三区四区在线观看 | 写真福利理论片在线播放| 久久99精品久久久水蜜桃| 国产亚洲人成网站| 精品色999| 中文在线а√天堂| 日本一二三区视频免费高清| 日本中文不卡| 日本韩国在线不卡| 亚洲国产另类 国产精品国产免费| 国产精品入口麻豆原神| 国产日韩一区| 久久中文字幕导航| 91福利在线尤物| 99久久99久久精品国产片| 亚洲韩国日本中文字幕| 18成人在线观看| 久久国产精品色| 久久综合88| 99综合久久| 日本高清成人vr专区|