成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL Server執(zhí)行動(dòng)態(tài)SQL兩種正確方式

數(shù)據(jù)庫(kù) SQL Server
動(dòng)態(tài)SQL大家經(jīng)常都會(huì)用到,它一般是根據(jù)用戶輸入或外部條件動(dòng)態(tài)組合的SQL語(yǔ)句塊。動(dòng)態(tài)SQL能靈活的發(fā)揮SQL強(qiáng)大的功能、方便的解決一些其它方法難以解決的問題。

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語(yǔ)句塊。動(dòng)態(tài)SQL能靈活的發(fā)揮SQL強(qiáng)大的功能、方便的解決一些其它方法難以解決的問題。相信使用過動(dòng)態(tài)SQL的人都能體會(huì)到它帶來(lái)的便利,然而動(dòng)態(tài)SQL有時(shí)候在執(zhí)行性能(效率)上面不如靜態(tài)SQL,而且使用不恰當(dāng),往往會(huì)在安全方面存在隱患(SQL 注入式攻擊)。

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

EXECUTE

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

SP_EXECUTESQL

執(zhí)行可以多次重復(fù)使用或動(dòng)態(tài)生成的 Transact-SQL 語(yǔ)句或批處理。Transact-SQL 語(yǔ)句或批處理可以包含嵌入?yún)?shù)。在批處理、名稱作用域和數(shù)據(jù)庫(kù)上下文方面,SP_EXECUTESQL 與 EXECUTE 的行為相同。SP_EXECUTESQL stmt 參數(shù)中的 Transact-SQL 語(yǔ)句或批處理在執(zhí)行 SP_EXECUTESQL 語(yǔ)句時(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ù)庫(kù)上下文所作的更改只在 SP_EXECUTESQL 語(yǔ)句結(jié)束前有效。

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

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

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

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

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

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

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

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

查詢出來(lái)沒有結(jié)果,沒有聲明參數(shù)長(zhǎng)度。

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

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

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

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

如下圖所示:

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

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

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

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


 

 

【編輯推薦】

SQL SERVER視圖對(duì)查詢效率的提高

SQL SERVER內(nèi)部函數(shù)大全

SQL Server變量賦值的方法

Java調(diào)用Sql Server存儲(chǔ)過程

SQL Server創(chuàng)建視圖的語(yǔ)法

責(zé)任編輯:段燃 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-11-24 08:54:33

2010-10-21 16:24:18

sql server升

2024-02-04 09:24:45

MyBatisSQL語(yǔ)句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動(dòng)態(tài)載入

2010-07-05 15:12:30

SQL Server主

2010-09-02 16:28:03

SQL刪除

2011-03-03 10:26:04

Pureftpd

2009-11-13 10:20:44

2010-07-08 10:38:24

MS SQL Serv

2011-04-06 11:05:21

SQL Server數(shù)交換數(shù)據(jù)

2010-07-13 15:39:23

SQL Server

2010-09-13 13:05:03

sql server分

2010-11-10 13:22:41

SQL Server備

2010-11-09 13:09:58

SQL Server分

2010-07-06 09:33:07

SQL Server遠(yuǎn)

2023-01-30 08:41:07

MyBatisSQL語(yǔ)句
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 成人二区 | 国产精品.xx视频.xxtv | 亚洲综合在线视频 | 久草电影网 | 日韩精品一二三 | 网站国产 | 日韩在线免费观看视频 | 亚洲色欲色欲www | 欧美日韩国产高清 | 亚洲毛片在线 | 欧美午夜精品 | 国产成人精品网站 | 日韩免费一区二区 | av一级久久 | 久久久久国产一区二区三区 | 亚洲成人动漫在线观看 | 男女国产视频 | 欧美黄色网 | www.国产日本 | 日韩国产欧美视频 | 国产精品精品视频一区二区三区 | 久久毛片 | 国产精品久久久久久久久久久久久 | www.youjizz.com日韩 | 巨大黑人极品videos精品 | 久久综合一区二区 | 欧美综合在线视频 | 黑人巨大精品欧美一区二区免费 | 亚洲一区二区电影网 | 欧美日韩国产中文 | 欧美一级黄色片免费观看 | a级片www | 亚洲 欧美 另类 日韩 | 黄色在线免费观看 | 亚洲欧美在线一区 | 91免费看片 | www.成人.com| 久久国产综合 | 青青草av网站 | 麻豆精品一区二区三区在线观看 | 久久久免费电影 |