如何在T / SQL中设置变量时从Integration Services Catalog执行SSIS包?

时间:2016-08-08 17:23:22

标签: sql-server ssis sql-server-2016

我最近继承了一个数据库,其中包含一个存储过程,该存储过程使用xp_cmdshell运行SSIS包,同时向包中添加单个用户变量(下面的代码)。作为我们迁移到SQL Server 2016(来自SQL Server 2008R2)的一部分,我正在尝试更改此存储过程,而是从名为SSISDB的Integration Services目录中调用该包。 我遇到的问题是我似乎无法弄清楚如何以它识别的方式将该变量传递给包!

旧代码:

DECLARE @Report_id INT = 63936
   ,@result INT
   ,@dtsExecCmd VARCHAR(4000)
   ,@params INT
   ,@path VARCHAR(500);
DECLARE @sif_report_object_ref_id VARCHAR(32)
   ,@error_count INT;

SET @result = 0;

SET @path = 'E:\OldServerFiles\Deployment\Package.dtsx';
SET @params = @Report_id; 

SET @dtsExecCmd = 'dtexec /F ' + @path; 
SET @dtsExecCmd = @dtsExecCmd
    + ' /SET "\package.Variables[User::Report_Id].Properties[Value]";"\"'
    + CAST(@params AS VARCHAR(10)) + '\""';

EXEC @result = [sys].[xp_cmdshell] @dtsExecCmd, [no_output];
PRINT @result;

以下是我到目前为止所执行的内容,但是它使用 Report_id 参数的默认值执行:

DECLARE @execution_id BIGINT
EXEC [SSISDB].[catalog].[create_execution] @package_name=N'Package.dtsx', @execution_id=@execution_id OUTPUT, @folder_name=N'TestProject', @project_name=N'TestReportETLPackage', @use32bitruntime=False, @reference_id=NULL
SELECT @execution_id
DECLARE @var0 SMALLINT = 3
DECLARE @ReportId INT = 63936
EXEC [SSISDB].[catalog].[set_execution_parameter_value] @execution_id,  @object_type=50, @parameter_name=N'LOGGING_LEVEL', @parameter_value=@var0
-- something goes in here for User::Report_Id as a package variable...
EXEC [SSISDB].[catalog].[start_execution] @execution_id
GO

1 个答案:

答案 0 :(得分:1)

你应该用一个参数替换这个变量,这样它就可以从外面直接设置,并且清楚地告诉开发人员它应该以这种方式提供。

作为临时修复,你应该发现类似下面的东西。

EXEC [catalog].[set_execution_property_override_value]
  @execution_id = @execution_id,
  @property_path = '\package.Variables[User::Report_Id].Properties[Value]',
  @property_value = @Report_id,
  @sensitive = 0;