兩種方式:exec (sqlStr);或exec sp_executesql @sqlStr;絕大多數情況下,應使用第二種方式來執行動態sql。因為這種方式能重用執行計划,並且更安全。
參考例子:https://bbs.csdn.net/topics/380030146
例如:
DECLARE @csIds VARCHAR(512) DECLARE @rc nvarchar(500) SET @csIds=(SELECT CsIdList FROM PinZhuan WHERE PZId = 20) SET @rc = 'SELECT ID,CsShowName from SCsinfoSource WHERE ID IN ('+@csIds+')' EXEC sp_executesql @rc
或者
EXEC sp_executesql N'SELECT ID,CsShowName from SCsinfoSource WHERE ID IN ('+@csIds+')'
或者
DECLARE @csIds VARCHAR(512) SET @csIds=(SELECT CsIdList FROM PinZhuan WHERE PZId = 20) EXEC('SELECT ID,CsShowName from SCsinfoSource WHERE ID IN ('+@csIds+')')