如何存储 EXEC sys.sp_executesql 的结果
How to store result of EXEC sys.sp_executesql
如何将 exec
的结果存储到变量中?
这是我将数据存储在变量中的尝试:
DECLARE @oltp VARCHAR(50) SET @oltp = 'emp'
DECLARE @wh VARCHAR(25) SET @wh = '_wh'
DECLARE @DatabaseName SYSNAME = @oltp + @wh;
DECLARE @oltp_data_days NVARCHAR(500)
DECLARE @Params NVARCHAR(500)
DECLARE @vi int
SET @oltp_data_days = N'(SELECT datediff(DAY, MIN(business_date), GETDATE()) AS keep_days
FROM '+QUOTENAME(@DatabaseName)+'..sales
WHERE business_date > ''1/1/2000 00:00:00'')'
EXEC sp_executesql @oltp_data_days = @oltp_data_days
, @Params = N'@vi INT OUTPUT'
, @vi = @vi OUTPUT
我得到的结果为 Null。
像这样:
declare @sql nvarchar(max) = N'set @vi = (select 3 as keep_days)'
declare @vi int
exec sp_executesql @sql, N'@vi int output', @vi = @vi output
select @vi
如何将 exec
的结果存储到变量中?
这是我将数据存储在变量中的尝试:
DECLARE @oltp VARCHAR(50) SET @oltp = 'emp'
DECLARE @wh VARCHAR(25) SET @wh = '_wh'
DECLARE @DatabaseName SYSNAME = @oltp + @wh;
DECLARE @oltp_data_days NVARCHAR(500)
DECLARE @Params NVARCHAR(500)
DECLARE @vi int
SET @oltp_data_days = N'(SELECT datediff(DAY, MIN(business_date), GETDATE()) AS keep_days
FROM '+QUOTENAME(@DatabaseName)+'..sales
WHERE business_date > ''1/1/2000 00:00:00'')'
EXEC sp_executesql @oltp_data_days = @oltp_data_days
, @Params = N'@vi INT OUTPUT'
, @vi = @vi OUTPUT
我得到的结果为 Null。
像这样:
declare @sql nvarchar(max) = N'set @vi = (select 3 as keep_days)'
declare @vi int
exec sp_executesql @sql, N'@vi int output', @vi = @vi output
select @vi