Passing Variables as Parameters in Execute SQL Task in SSIS
Executing dynamic SQL operations often necessitates passing variables as parameters to make queries more versatile. In an SSIS package, you encounter such a scenario when you need to pass external values to a temporary table creation query in the Execute SQL Task.
Question:
Consider an SSIS package where data from a flat file is inserted into a table. Within this package, an Execute SQL Task is utilized to create a temp table called ##temptable with specific columns. Following this, data is inserted into ##temptable based on certain filter criteria. The requirement is to pass these filter criteria dynamically using variables created within the SSIS package.
Solution:
To achieve dynamic parameter passing, configure the Execute SQL Task as follows:
CREATE PROCEDURE [dbo].[usp_temptable] ( @date DATETIME, @portfolioId INT, @stype NVARCHAR(50) ) AS BEGIN INSERT INTO [tempdb].dbo.##temptable (date, companyname, price, PortfolioId, stype) SELECT date, companyname, price, PortfolioId, stype FROM ProgressNAV WHERE (Date = @date) AND (PortfolioId = @portfolioId) AND (stype in (@stype)) ORDER BY CompanyName END
The above is the detailed content of How to Pass SSIS Variables as Parameters to an Execute SQL Task for Dynamic SQL?. For more information, please follow other related articles on the PHP Chinese website!