miércoles, 24 de octubre de 2018

SSIS 2017 - Crear PATH dinámico para obtener un origen de datos (.csv)

Primer paso crear una variable global en el paquete. CONTROL FLOW.
En este caso la llamé ruta_entrada, es de tipo String, y como pide un Value le podría indicar cualquiera, pero opto por poner el que supuestamente tendrá en producción.-





Creo una nueva conexión de archivo, como SSIS exige que de una ruta con el archivo valido, tomo mi archivo de entrada y lo dejo en el escritorio (que no será la ruta final ya que será dinámica), así puede reconocer las columnas.


En  Advanced le indico nombres a las columnas y puedo indicar el tipo de datos y el largo.




Luego en mi conexión de archivo plano recién creada voy a setear una Expresión, así que hago click derecho y Propiedades


En las propiedas marco ... en EXPRESIONES , para crearle una expresión a la conexión.-




Ahora voy a explicar los números, que obviamente es el orden en el que debemos configurar:

1. Selecciono ConnectionString , ya que esa es la propiedad que será REEMPLAZADA en tiempo de ejecución.
2.Presiono los [...] y abrirá la ventana Expresion Builder donde se construirá la Expresión que va a reemplazar el path original que pusimos anteriormente y con que? con nuestra variable global creada al principo, asi que la arrastro al cuadro Expression.
3.Presiono OK para guardar los cambios
4. Ahora veremos como expresión nuestra variable.-







Que falta?

Actualizar la variable global con el valor (en este caso la ruta, que será obtenida desde la Base de Datos).

Para realizar la actualización (que será obviamente en tiempo de ejecución) creo una tarea SQL TASK EDITOR , 
importante!! el Result Set lo marco en SINGLE ROW y en SQL STATEMENT indico la consulta de base de datos, que como resultado debe entregarnos la famosa RUTA DINAMICA.




Acá la ruta la obtiene mediante un SP, pero puede ser un SELECT directo.- importante, es que el recordar que el nombre de la salida es el mismo que usaremos mas adelante en el RESUL SET.- 

RESULT SET
Expliquemos los numeros:

1.Para agregar el result set y PISAR el VALUE de nuestra variable global llamada ruta_entrada.
2.Result Name, es el nombre que tiene la salida de nuestro script o sp.-
3.Variable Name la variable que resultará "pisada" en tiempo de ejecución.-
4. OK. para guardar los cambios.

Finalmente ya podemos hacer uso de un origen de archivo plano con nuestra ruta dinamica.-
adjunto foto con un ejemplo.-

en un DATA FLOW, genero un FLAT FILE SOURCE y en el FLAT FIULE CONECCTION MANAGER elijo la conexión creada inicialmente, y LISTO! en tiempo de ejecución el ETL usará la ruta que devuelva el SP y no la que pusimos en DURO.-



FOTOS -->>











fuente de conocimiento : https://geeks.ms/gelexgaray/2006/10/10/paths-relativos-en-integration-services/