Execute Package Task
Applies to: SQL Server SSIS Integration Runtime in Azure Data Factory
The Execute Package task extends the enterprise capabilities of Integration Services by letting packages run other packages as part of a workflow.
You can use the Execute Package task for the following purposes:
Breaking down complex package workflow. This task lets you break down workflow into multiple packages, which are easier to read, test, and maintain. For example, if you are loading data into a star schema, you can build a separate package to populate each dimension and the fact table.
Reusing parts of packages. Other packages can reuse parts of a package workflow. For example, you can build a data extraction module that can be called from different packages. Each package that calls the extraction module can perform different data scrubbing, filtering, or aggregation operations.
Grouping work units. Units of work can be encapsulated into separate packages and joined as transactional components to the workflow of a parent package. For example, the parent package runs the accessory packages, and based on the success or failure of the accessory packages, the parent package either commits or rolls back the transaction.
Controlling package security. Package authors require access to only a part of a multipackage solution. By separating a package into multiple packages, you can provide a greater level of security, because you can grant an author access to only the relevant packages.
A package that runs other packages is generally referred to as the parent package, and the packages that a parent workflow runs are called child packages.
Integration Services includes tasks that perform workflow operations, such as executing executables and batch files. For more information, see Execute Process Task.
Running Packages
The Execute Package task can run child packages that are contained in the same project that contains the parent package. You select a child package from the project by setting the ReferenceType property to Project Reference, and then setting the PackageNameFromProjectReference property.
Note
The ReferenceType option is ready-only and set to External Reference if the project that contains the package has not been converted to the project deployment model. Deploy Integration Services (SSIS) Projects and Packages.
The Execute Package task can also run packages stored in the SQL Server msdb database and packages stored in the file system. The task uses an OLE DB connection manager to connect to SQL Server or a File connection manager to access the file system. For more information, see OLE DB Connection Manager and Flat File Connection Manager.
The Execute Package task can also run a database maintenance plan, which lets you manage both SSIS packages and database maintenance plans in the same Integration Services solution. A database maintenance plan is similar to an SSIS package, but a plan can include only database maintenance tasks, and it is always stored in the msdb database.
If you choose a package stored in the file system, you must provide the name and location of the package. The package can reside anywhere in the file system; it does not have to be in the same folder as the parent package.
The child package can be run in the process of the parent package, or it can be run in its own process. Running the child package in its own process requires more memory, but it provides more flexibility. For example, if the child process fails, the parent process can continue to run.
Alternatively, sometimes you want the parent and child packages to fail together as one unit, or you might not want to incur the additional overhead of another process. For example, if a child process fails and subsequent processing in the parent process of the package depends on success of the child process, the child package should run in the process of the parent package.
By default, the ExecuteOutOfProcess property of the Execute Package task is set to False, and the child package runs in the same process as the parent package. If you set this property to True, the child package runs in a separate process. This may slow down the launching of the child package. In addition, if you set the property to True, you cannot debug the package in a tools-only install. You must install Integration Services. For more information, see Install Integration Services
Extending Transactions
The transaction that the parent package uses can extend to the child package; therefore, the work both packages perform can be committed or rolled back. For example, the database inserts that the parent package performs can be committed or rolled back, depending on the database inserts that the child package performs, and vice versa. For more information, see Inherited Transactions.
Propagating Logging Details
The child package that the Execute Package task runs may or may not be configured to use logging, but the child package will always forward the log details to the parent package. If the Execute Package task is configured to use logging, the task logs the log details from the child package. For more information, see Integration Services (SSIS) Logging.
Passing Values to Child Packages
Frequently a child package uses values passed to it by another package that calls it, ordinarily its parent package. Using values from a parent package is useful in scenarios such as the following:
Parts of a larger workflow are assigned to different packages. For example, one package downloads data on a nightly basis, summarizes the data, assigns summary data values to variables, and then passes the values to another package for additional processing of the data.
The parent package dynamically coordinates tasks in a child package. For example, the parent package determines the number of days in a current month and assigns the number to a variable, and the child package performs a task that number of times.
A child package requires access to data that is dynamically derived by the parent package. For example, the parent package extracts data from a table and loads the rowset into a variable, and the child package performs additional operations on the data.
You can use the following methods to pass values to a child package:
Package Configurations
Integration Services provides a configuration type, the Parent Package Variable configuration, for passing values from parent to child packages. The configuration is built on the child package and uses a variable in the parent package. The configuration is mapped to a variable in the child package, or to the property of an object in the child package. The variable can also be used in the scripts used by the Script task or Script component.
Parameters
You can configure the Execute Package Task to map parent package variables or parameters, or project parameters, to child package parameters. The project must use the project deployment model and the child package must be contained in the same project that contains the parent package. For more information, see Execute Package Task Editor.
Note
If the child package parameter is not sensitive and is mapped to a parent parameter that is sensitive, the child package will fail to run.
The following mapping conditions are supported:
Sensitive, child package parameter is mapped to a sensitive, parent parameter
Sensitive, child package parameter is mapped to a non-sensitive, parent parameter
Non-sensitive, child package parameter is mapped to a non-sensitive, parent parameter
The parent package variable can be defined in the scope of the Execute Package task or in a parent container such as the package. If multiple variables with the same name are available, the variable defined in the scope of the Execute Package task is used, or the variable that is closest in scope to the task.
For more information, see Use the Values of Variables and Parameters in a Child Package.
Accessing Parent Package Variables
Child packages can access parent package variables by using the Script task. When you enter the name of the parent package variable on the Script page in the Script Task Editor, don't include User: in the variable name. Otherwise, the child package doesn't locate the variable when you run the parent package.
Configuring the Execute Package Task
You can set properties through SSIS Designer or programmatically.
For more information about the properties that you can set in SSIS Designer, click the following topic:
For more information about how to set these properties in SSIS Designer, click the following topic:
Configuring the Execute Package Task Programmatically
For more information about programmatically setting these properties, click the following topic:
Execute Package Task Editor
Use the Execute Package Task Editor to configure the Execute Package Task. The Execute Package task extends the enterprise capabilities of Integration Services by letting packages run other packages as part of a workflow.
What do you want to do?
Open the Execute Package Task Editor
Open an Integration Services project in Visual Studio that contains an Execute Package task.
Right-click the task in the SSIS Designer, and then click Edit.
Set the Options on the General Page
Name
Provide a unique name for the Execute Package task. This name is used as the label in the task icon.
Note
Task names must be unique within a package.
Description
Type a description of the Execute Package task.
Set the Options on the Package Page
ReferenceType
Select Project Reference for child packages that are in the project. Select External Reference for child packages that are located outside the package
Note
The ReferenceType option is ready-only and set to External Reference if the project that contains the package has not been converted to the project deployment model. Deploy Integration Services (SSIS) Projects and Packages.
Password
If the child package is password protected, provide the password for the child package, or click the ellipsis button (...) and create a new password for the child package.
ExecuteOutOfProcess
Specify whether the child package runs in the process of the parent package or in a separate process. By default, the ExecuteOutOfProcess property of the Execute Package task is set to False, and the child package runs in the same process as the parent package. If you set this property to true, the child package runs in a separate process. This may slow down the launching of the child package. In addition, if set the property to true, you cannot debug the package in a tools-only install; you must install the Integration Services product. For more information, see Install Integration Services.
ReferenceType Dynamic Options
ReferenceType = External Reference
Location
Select the location of the child package. This property has the options listed in the following table.
Value | Description |
---|---|
SQL Server | Set the location to an instance of SQL Server. |
File system | Set the location to the file system. |
Connection
Select the type of storage location for the child package.
PackageNameReadOnly
Displays the package name.
ReferenceType = Project Reference
PackageNameFromProjectReference
Select a package contained in the project, to be the child package.
Location Dynamic Options
Location = SQL Server
Connection
Select an OLE DB connection manager in the list, or click <New connection...> to create a new connection manager.
Related Topics: OLE DB Connection Manager
PackageName
Type the name of the child package, or click the ellipsis (...) and then locate the package.
Location = File system
Connection
Select a File connection manager in the list, or click <New connection...> to create a new connection manager.
Related Topics: File Connection Manager
PackageNameReadOnly
Displays the package name.
Set the Options on the Parameter Bindings Page
You can pass values from the parent package or the project, to the child package. The project must use the project deployment model and the child package must be contained in the same project that contains the parent package.
For information about converting projects to the project deployment model, see Deploy Integration Services (SSIS) Projects and Packages.
Child package parameter
Enter or select a name for the child package parameter.
Binding parameter or variable
Select the parameter or variable that contains the value that you want to pass to the child package.
Add
Click to map a parameter or variable to a child package parameter.
Remove
Click to remove a mapping between a parameter or variable and a child package parameter.