Compartir a través de


Implementar un proyecto de SSIS con código C# en una aplicación .NET

Se aplica a: SQL Server SSIS Integration Runtime en Azure Data Factory

En este inicio rápido se muestra cómo escribir código C# para conectarse a un servidor de bases de datos e implementar un proyecto de SSIS.

Para crear una aplicación de C#, puede usar Visual Studio, Visual Studio Code u otra herramienta de su elección.

Requisitos previos

Antes de empezar, asegúrese de tener instalado Visual Studio o Visual Studio Code. Descargue la edición gratuita de Visual Studio Community Edition o Visual Studio Code desde Descargas de Visual Studio.

Un servidor de Azure SQL Database escucha en el puerto 1433. Si está intentando conectarse a un servidor de Azure SQL Database desde un firewall corporativo, este puerto debe estar abierto en el firewall corporativo para poder conectarse correctamente.

Plataformas compatibles

Puede usar la información que aparece en este inicio rápido para implementar un proyecto de SSIS en las siguientes plataformas:

No puede usar la información que aparece en este inicio rápido para implementar un paquete de SSIS en SQL Server en Linux. Para más información sobre cómo ejecutar paquetes en Linux, vea Extract, transform, and load data on Linux with SSIS (Extraer, transformar y cargar datos en Linux con SSIS).

Para Azure SQL Database, obtener la información de conexión

Para implementar el proyecto en Azure SQL Database, debe obtener la información de conexión necesaria para conectarse a la base de datos del catálogo de SSIS (SSISDB). Necesita el nombre completo y la información de inicio de sesión del servidor en los procedimientos siguientes.

  1. Inicie sesión en Azure Portal.
  2. Seleccione Bases de datos SQL en el menú izquierdo y, después, seleccione la base de datos SSISDB en la página Bases de datos SQL.
  3. En la página Introducción de la base de datos, compruebe el nombre completo del servidor. Mantenga el puntero del ratón sobre el nombre del servidor para ver la opción Haga clic para copiar.
  4. Si olvida la información de inicio de sesión del servidor de Azure SQL Database, navegue a la página del servidor de SQL Database para ver el nombre del administrador del servidor. Si es necesario, puede restablecer la contraseña.
  5. Haga clic en Mostrar las cadenas de conexión de la base de datos.
  6. Revise la cadena de conexión ADO.NET completa. De manera opcional, el código puede usar una clase SqlConnectionStringBuilder para volver a crear esta cadena de conexión con los valores de parámetros individuales que proporcione.

Método de autenticación compatible

Consulte Métodos de autenticación para la implementación.

Crear un nuevo proyecto de Visual Studio

  1. En Visual Studio, elija Archivo, Nuevo, Proyecto.
  2. En el cuadro de diálogo Nuevo proyecto, expanda Visual C#.
  3. Seleccione Aplicación de consola y escriba deploy_ssis_project como nombre del proyecto.
  4. Haga clic en Aceptar para crear y abrir el nuevo proyecto en Visual Studio.

Agregar referencias

  1. En el Explorador de soluciones, haga clic con el botón derecho en la carpeta Referencias y seleccione Agregar referencia. Se abre el cuadro de diálogo Administrador de referencias.
  2. En el cuadro de diálogo Administrador de referencias, expanda Ensamblados y seleccione Extensiones.
  3. Seleccione las dos referencias siguientes para agregarlas:
    • Microsoft.SqlServer.Management.Sdk.Sfc
    • Microsoft.SqlServer.Smo
  4. Haga clic en el botón Examinar para agregar una referencia a Microsoft.SqlServer.Management.IntegrationServices. [Este ensamblado solo se instala en la caché global de ensamblados (GAC)]. Se abre el cuadro de diálogo Seleccionar archivos para referencia.
  5. En el cuadro de diálogo Seleccionar archivos para referencia, vaya a la carpeta de GAC que contiene el ensamblado. Normalmente, esta carpeta es C:\Windows\assembly\GAC_MSIL\Microsoft.SqlServer.Management.IntegrationServices\14.0.0.0__89845dcd8080cc91.
  6. Seleccione el ensamblado (es decir, el archivo .dll) en la carpeta y haga clic en Agregar.
  7. Haga clic en Aceptar para cerrar el cuadro de diálogo Administrador de referencias y agregue las tres referencias. Para asegurarse de que existen las referencias, consulte la lista Referencias en el Explorador de soluciones.

Agregar el código C#

  1. Abra Program.cs.

  2. Reemplace el contenido de Program.cs por el código siguiente. Agregue los valores adecuados para el servidor, la base de datos, el usuario y la contraseña.

Nota

En el ejemplo siguiente se usa la autenticación de Windows. Para usar la autenticación de SQL Server, reemplace el argumento Integrated Security=SSPI; por User ID=<user name>;Password=<password>;. Si se va a conectar a un servidor de Azure SQL Database, no puede usar la autenticación de Windows.

using Microsoft.SqlServer.Management.IntegrationServices;
using System;
using System.Data.SqlClient;
using System.IO;

namespace deploy_ssis_project
{
    class Program
    {
        static void Main(string[] args)
        {
            // Variables
            string targetServerName = "localhost";
            string targetFolderName = "Project1Folder";
            string projectName = "Integration Services Project1";
            string projectFilePath = @"C:\Projects\Integration Services Project1\Integration Services Project1\bin\Development\Integration Services Project1.ispac";

            // Create a connection to the server
            string sqlConnectionString = "Data Source=" + targetServerName +
                ";Initial Catalog=master;Integrated Security=SSPI;";
            SqlConnection sqlConnection = new SqlConnection(sqlConnectionString);

            // Create the Integration Services object
            IntegrationServices integrationServices = new IntegrationServices(sqlConnection);

            // Get the Integration Services catalog
            Catalog catalog = integrationServices.Catalogs["SSISDB"];

            // Create the target folder
            CatalogFolder folder = new CatalogFolder(catalog,
                targetFolderName, "Folder description");
            folder.Create();

            Console.WriteLine("Deploying " + projectName + " project.");

            byte[] projectFile = File.ReadAllBytes(projectFilePath);
            folder.DeployProject(projectName, projectFile);

            Console.WriteLine("Done.");
        }
    }
}

Ejecución del código

  1. Para ejecutar la aplicación, presione F5.
  2. En SSMS, compruebe que se ha implementado el proyecto.

Pasos siguientes