执行一个内容为SQL语句的字符串
两种方式: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+')')
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步