SSIS Tutorial: Creating a Simple ETL Package


Microsoft SQL Server Integration Services (SSIS) is a platform for building high performance data integration solutions, including extraction, transformation, and load (ETL) packages for data warehousing. SSIS includes graphical tools and wizards for building and debugging packages; tasks for performing workflow functions such as FTP operations, executing SQL statements, and sending e-mail messages; data sources and destinations for extracting and loading data; transformations for cleaning, aggregating, merging, and copying data; a management service, the Integration Services service for administering package execution and storage; and application programming interfaces (APIs) for programming the Integration Services object model.

In this tutorial, you will learn how to use SSIS Designer to create a simple Microsoft SQL Server Integration Services package. The package that you create takes data from a flat file, reformats the data, and then inserts the reformatted data into a fact table. In following lessons, the package is expanded to demonstrate looping, package configurations, logging and error flow.

When you install the sample data that the tutorial uses, you also install the completed versions of the packages that you will create in each lesson of the tutorial. By using the completed packages, you can skip ahead and begin the tutorial at a later lesson if you like. If this is your first time working with packages or the new development environment, we recommend that you begin with Lesson1.

The best way to become acquainted with the new tools, controls and features available in Microsoft SQL Server Integration Services is to use them. This tutorial walks you through SSIS Designer to create a simple ETL package that includes looping, configurations, error flow logic and logging.

This tutorial is intended for users familiar with fundamental database operations, but who have limited exposure to the new features available in SQL Server Integration Services.

To use this tutorial, your system must have the following components installed:

  • SQL Server with the AdventureWorksDW2012 database. To enhance security, the sample databases are not installed by default. To download the AdventureWorksDW2012 database, see Adventure Works for SQL Server 2012.

    System_CAPS_ICON_important.jpg Important

    When you attach the database (*.mdf file), SQL Server Management Studio will by default search for an .ldf file. You must manually remove the .ldf file before clicking OK in the Attach Databases dialog box.

    For more information about attaching databases, see Attach a Database.

  • Sample data. The sample data is included with the SSIS lesson packages. To download the sample data and the lesson packages, do the following.

    1. Navigate to Integration Services Product Samples

    2. Click the DOWNLOADS tab.

    3. Click the file.

Lesson 1: Creating the Project and Basic Package
In this lesson, you will create a simple ETL package that extracts data from a single flat file, transforms the data using lookup transformations and finally loads the result into a fact table destination.

Lesson 2: Adding Looping
In this lesson, you will expand the package you created in Lesson 1 to take advantage of new looping features to extract multiple flat files into a single data flow process.

Lesson 3: Adding Logging
In this lesson, you will expand the package you created in Lesson 2 to take advantage of new logging features.

Lesson 4: Adding Error Flow Redirection
In this lesson, you will expand the package you created in lesson 3 to take advantage of new error output configurations.

Lesson 5: Adding Package Configurations for the Package Deployment Model
In this lesson, you will expand the package you created in Lesson 4 to take advantage of new package configuration options.

Lesson 6: Using Parameters with the Project Deployment Model
In this lesson, you will expand the package you created in Lesson 5 to take advantage of using new parameters with the project deployment model.