www.miguelciacci.com.ar - Inauguración de mi Nuevo Site!

2 comentarios

Buenos días a todos mis apreciados lectores! escribo este post para notificarles que en el día de ayer he puesto en producción mi nuevo Site. Está desarrollado en Silverlight 2.0 y ASP.Net, para ello he utilizado como herramientas Visual Studio 2008 y Expression Blend 2.0. Por ahora cuenta con 4 secciones principales pero con el tiempo se irán incrementando. Las Secciones son:

a) My CV = desde donde pueden acceder a mi Curriculum Vitae, donde se detallan mis experiencias tanto académicas como laborales y profesionales.

b) My TECH Blog = nos remite a mi blog técnico, en el cual se encuentran leyendo este post.

c) My Personal Pics = nos redirecciona a mi album personal de fotos. Dudo que alguien esté interesado en verlas pero por si acaso... jeje

d) Contact me = es una via de contacto de los visitantes hacia con mi persona. A través de un formulario simple pueden enviarme sus inquietudes, consultas, sugerencias, opiniones o lo que se les ocurra.




Importante: para poder visualizar el sitio deben tener instalado en su PC el cliente Silverlight. Dicho cliente puede descargarse desde el sitio oficial de Microsoft Silverlight haciendo click aquí.

.Net - Enviar mail con servidor que requiere autenticación

0 comentarios

A continuación les pongo el código necesario para poder enviar un mail desde .Net 2.0 o superior utilizando un servidor de correo que requiere Autenticación. El código es:


MailMessage mail = new MailMessage();
SmtpClient smtp = new SmtpClient("mail.midominio.com", 25);

mail.From = new MailAddress("mail@midominio.com");
mail.To.Add("destinatario@mail.com");
mail.Subject = "Asunto";
mail.Body = "Aquí se debe ingresar el mensaje...";
mail.IsBodyHtml = true;
smtp.EnableSsl = false;

smtp.Credentials = new NetworkCredential("miUsuario","miClave");

// Prioridad
mail.Priority = MailPriority.Normal;

//Esto es porque el Servidor requiere Autenticacion
smtp.UseDefaultCredentials = false;

smtp.Send(mail);

Se debe tener en cuenta que hay que incluir los namespaces System.Net y System.Net.Mail.

Si desean saber más en detalle para que sirve cada linea descripta anteriormente, los invito a que lean el post de un colega (hagan click en el siguiente link).

Saludos.

Silverlight 2.0 - Error Could not download the silverlight application. Check web server settings

0 comentarios

Es muy común que cuando subimos nuestra aplicación realizada en Silverlight 2.0 nos encontremos con el error "Could not download the silverlight application. Check web server settings".



Esto se debe a que en el servidor faltan añadir algunos MYME Types. Debemos añadir los siguientes MYME Types para que nuestra aplicación funcione correctamente:

.xap - application/x-silverlight-app
.manifest - application/manifest
.xaml - application/xaml+xml
.dll - application/x-msdownload
.application - application/x-ms-application
.xbap - application/x-ms-xbap
.deploy - application/octet-stream
.xps - application/vnd.ms-xpsdocument

Espero les sea de utilidad este post...

Saludos

ASP.NET AJAX - Control UpdateProgress

0 comentarios

Continuando con los controles de AJAX para ASP.NET ahora toca hablarles del UpdateProgress. Este control permite mostrar por pantalla que existe un retraso al traer los datos desde el servidor. Este control crea un "DIV" con todo su contenido dentro, el que permanece invisible hasta que el UpdatePanel hace un PostBack Asíncrono y espera la respuesta del servidor.

El contenido que se muestra que puede ser un mensaje o cualquier contenido HTML debe colocarse en el tag .

Se puede utilizar un UpdateProgress para toda la página o utilizar un UpdateProgress para cada UpdatePanel, en este caso debemos usar la propiedad AssociatedUpdatePanelID para indicarle con cual UpdatePanel se relaciona.

La propiedad DisplayAfter permite establecer el tiempo mínimo a esperar antes de que sea mostrado el contenido, para evitar parpadeos en caso de ser muy rápida la respuesta del servidor. Por Default es de 500 ms.

La propiedad DynamicLayout permite reservar el espacio del UpdateProgress o no según sea True o False. Si es True no reservará el espacio desplazando el resto del contenido de la página cuando se haga visible.

Ejemplo



Y en Code-behind tendremos:

ASP.NET AJAX - Control Timer

0 comentarios

Este control se utiliza para disparar periódicamente refrescos de página del lado del cliente. Requiere la presencia del ScriptManager en la página que lo contiene.

La propiedad Interval es la que determina la periodicidad del refresco. Se pueden utilizar varios Timer en la misma página, pero si su interval es el mismo podemos utilizar uno solo añadiéndolo a la colección de Triggers de los diferentes UpdatePanel.

El evento Tick nos permite ejecutar código en el servidor en cada disparo del Timer. También podemos usar el Page_Load de la página que provoca el mismo efecto.



En el Code-behind tendremos:

Error al crear Nuevo Proyecto en Expression Blend 2.5 June 2008 Preview

0 comentarios

Buenas días a todos mis lectores, investigando sobre las nuevas tecnologías Microsoft, en este caso Expression Blend 2.5 June 2008 Preview me he topado con un error bastante curioso. Al intentar generar un nuevo proyecto de Silverlight 2.0 surgía la famosa ventana de reporte de error.

La Solución... investigando un poco por la web y luego de horas de aplicar la teoría de "prueba y error" pude hacer que este error desaparezca.
Los pasos a seguir son:
1. Desinstalar el Silverlight SDK desde Agregar o quitar Programas del Panel de Control.
2. Desintalar Expression Blend 2.5 June 2008 Preview, también desde el Panel de Control.
3. Reinstalar Expression Blend 2.5 June 2008 Preview.

Luego de estas acciones pude trabajar con normalidad en Expression Blend. Espero que les sea de ayuda este post.

Saludos!

Acreditando conocimientos... Administración, organización y entrega de proyectos de TI con Microsoft Solutions Framework 3.0

0 comentarios

Cómo ya les había comentado en un post anterior, mi próxima meta a nivel de certificaciones era el examen de Microsoft 70-301 (Administración, organización y entrega de proyectos de TI con Microsoft Solutions Framework 3.0). Finalmente y luego de muchas horas de dedicación, esfuerzo y por que no... sacrificio, lo he conseguido. Tanto estudio valió la pena, ya cuento con mi 2da certificación de Microsoft (3ra si contamos Solution Selling) y voy por más. Pero eso será el año próximo. Quiero agradecer tanto a Raona como a mis familiares y amigos que supieron comprenderme y brindarme su apoyo en todo momento. A todos aquellos que estén deseosos de rendir este examen, pues adelante, ya verán que es duro pero no es imposible... jeje

Saludos a todos!

ASP.NET AJAX - Triggers(Disparadores) del UpdatePanel

0 comentarios

Por default los controles dentro de un UpdatePanel actúan como disparadores del mismo, mientras que los controles que están sobre la pagina ocasionan un PostBack de toda la pagina de forma síncrona.
Se puede configurar un control externo al UpdatePanel para que ocasione el recargado asíncrono del panel.
Por código:



Por vista Diseño:



Los Tipos de Triggers son:
- PostBackTrigger: el control dentro del UpdatePanel provocará un PostBack completo de la página.
- AsyncPostBackTrigger: se usa para indicar que el control tanto si se encuentra dentro o fuera del UpdatePanel debe ocasionar una recarga asíncrona del mismo.

Por defecto la propiedad ChildrenAsTriggers es true permite que el control refresque asíncronamente el UpdatePanel. Si le ponemos el valor false deberemos usar el método Update() para provocar la carga asíncrona.

ASP.NET AJAX (Asynchronous Javascript And Xml)

0 comentarios

En este post quiero describir brevemente que es AJAX y cuales son su componentes esenciales. El objetivo de AJAX es conseguir que las páginas web respondan lo más rápidamente posible a las peticiones de los usuarios evitando recargar toda la página con información desde el servidor. Sus componentes principales en VS 2008 son:
- ScriptManager: registra el script de la librería cliente de AJAX en la pagina permitiendo ejecutar del lado del cliente una serie de funciones y extensiones de Javascript tales como el pintado parcial de las paginas o llamadas a servicios web desde código cliente.
Para gestionar los errores podemos usar:
a) Gestionar el evento AsyncPostBackError del ScriptManager que se dispara al producirse un error durante el PostBack asíncrono.
b) Poner texto en la propiedad AsyncPostBackErrorMessage que es el mensaje que se envía al navegador y se presenta en un alert.
Para gestionar el tiempo de espera usar AsyncPostBackTimeOut en el que indicamos el tiempo tras el cual el ScriptManager mostrara el error de falta de respuesta del servidor.
- UpdatePanel: permite que solo se refresquen los controles ubicados dentro suyo, sin necesidad de volver a cargar toda la página. Esto es posible gracias a la clase PageRequestManager que el ScriptManager incluye en el cliente.
La propiedad UpdateMode indica las circunstancias bajo las que se actualiza, puede ser:
UpdatePanelUpdateMode.Always el contenido del UpdatePanel se actualiza en todos los postbacks que ocurran en le pagina.
UpdatePanelUpdateMode.Conditional el contenido del UpdatePanel solo se actualiza cuando se dispara un Trigger de ese panel o a través de un Update() o si cuando el Panel esta anidado dentro de otro y este se actualiza.

SilverLight version 1.0

0 comentarios

Silverlight es una tecnologia multi-Navegador (IE, Firefox, etc.) y multi-Plataforma(Win, Linux, Mac, etc.) que permite el desarrollo de una nueva generación de interfaces de usuario potenciando el desarrollo de interfaces multimedia RIA (Rich Interactive Applications).
XAML (Extensible Application Markup Lenguaje) es un lenguaje declarativo, derivado de XML cuya finalidad principal es la de permitir definir la interfaz visual.
Silverlight es un complemento de navegador que representa XAML (al igual que el navegador representa xhtml o html) exponiendo su modelo de objeto de documentos (DOM) y su modelo de Eventos con lo cual podemos ejecutar código desde el lado cliente ahorrándonos la ida y procesamiento en el servidor. Se basa en la tecnología plug in por lo que se requiere la instalación de un pequeño componente para poder visualizar el contenido de Silverlight en nuestro navegador.
XAML está basado en texto y así se descarga en el cliente por lo que no da problemas en buscadores, firewalls, muy útil si se desea utilizar SEO (Search Engine Optimization). XAML es fundamentalmente vectorial, por lo que permite desarrollar con muy poco esfuerzo aplicaciones “Pixel free” independientes de la resolución.

Silverlight tiene herramientas orientadas al programador y al diseñador, estas son:
- Silverlight v1.0: plug in disponible para Win, Linux y Mac.
- VS2008: permite hacer desarrollos en Silverlight.
- Expression Blend 2: permite diseñar espectaculares experiencias interactivas en XAML sin necesidad de escribir ni una línea.
- Expression Encoder: permite codificar y mejorar ficheros de video para poder ser utilizados en silverlight.
- Expression Desing: herramienta de diseño vectorial que permite crear diseños y elementos silverlight.

WINDOWS WORKFLOW FUNDATION

0 comentarios

En este post voy a explicar en que consiste y como se conforma Windows WorkFlow Fundation (WF). WF Sirve para desarrollar aplicaciones disponiendo de una forma natural de expresar la lógica del negocio. Permite expresar la lógica de una forma natural sin entrar en las complicaciones de los lenguajes con las que esté construida.
La función principal de WF es facilitar la escritura de los procesos de negocio de forma declarativa, sin concentrándonos en el proceso que queremos implementar sin sacrificar la escalabilidad y robustez que ofrecen las nuevas tecnologías.

Arquitectura de WF
Todos los elementos del WF están basados en el principio de extensabilidad. Por este motivo es posible utilizarlo como “marco de trabajo” para incluirlo en otros productos de Microsoft ya existentes.
En la siguiente figura podemos ver las piezas fundamentales de la arquitectura del WF.




a) Capa Runtime = es el nucleo del WF y contiene la mayoria de los servicios críticos de WF. Estos servicios son:
Servicio de Ejecución: es el encargado de organizar la ejecución de las actividades y de los comportamientos más comunes de estos últimos (como eventos, manejo de excepciones, tracking, etc.)
Servicio de Scheduler: es uno de los servicios más importantes de WF. Se encarga de cómo se van a ejecutar los flujos de trabajo.
Motor de Reglas: permite crear y administrar las reglas que se evaluaran el ejecutar el programa.
b) Workflow Model = es donde los desarrolladores utilizaran la mayor parte de su tiempo ya que incluye las principales APIs y modelos del WF. Existen 2 modelos con los que se puede trabajar en WF, estos son:
Workflows Secuenciales: son los más utilizados debido a nuestra naturaleza de dividir las tareas en pasos.
Máquinas de Estado: permite definir diferentes estados y las transiciones que permiten cambiar de un estado a otro los que se asocian a eventos.
c) Hosting = se encarga de dar soporte de ejecución de WF permitiendo establecer los servicios necesarios, además de facilitar las comunicaciones de los flujos de trabajo con componentes externos tales como librerías u otros procesos.

Actividades (Workflow Model)
Las actividades pueden dividirse en:
- Act. de Proceso (tareas sencillas – code, delay, secuence, parallel, etc - )
- Act. de Control (Condicionales – if, while, etc - )
- Control de Excepciones
- Act. de Modelado (provee la funcionalidad necesaria para que nuestro flujo de trabajo pueda comunicarse con el proceso que los Aloja – ExternalDataExchangeService -)

Servicios (Hosting)
- Persistence (WorflowPersistenceService): permite que los flujos de trabajo sean durables en el tiempo a la espera de un determinado evento. WF proporciona una implementación de sqlWorkflowPersistenceService la que permite utilizar SQL Server como almacén de persistencia.
- Scheduler (WorkflowSchedulerService): permite configurar si deseamos que cada uno de nuestros flujos de trabajo se ejecuten en hilos separados o en el mismo hilo. Por defecto defaultWorkflowSchedulerService crea un nuevo hilo por cada instancia y con Manual WorkflowSchedulerService podemos establecer como lo deseamos.
- Tracking (WorkflowTrackingService): permite instrumentar un proceso de negocio y brinda un servicio de repositorio (BD) que poder explotar. Se basa en 2 elementos fundamentales: Tracking Profile: define un perfil de eventos que deben ser instrumentalizados (Ej: Act. o Flujos de trabajo) y Tracking Channel: es el repositorio (txt o BD) donde se depositan todas las trazas de información.

SSIS – Asignación dinámica de path (Directory) a un Foreach

0 comentarios

Buenas, es posible configurar dinámicamente el path (Directory) de un componente For Each. De este modo nuestros procesos pueden recorrer diferentes directorios configurados dinámicamente con solo modificar el fichero de configuración utilizado como “Package Configuration”.
Si ya contamos con un fichero de package configuration debemos editarlo, caso contrario, crearemos uno para poder anexar la funcionalidad que pretendemos (Si tienes dudas de cómo crear y/o editar ficheros de configuración puedes leer mis posts anteriores donde se explica claramente).
Una vez abierto el fichero de configuración en el paso donde debemos seleccionar las propiedades a exportar, debemos buscar el componente Foreach Loop Container dentro del Package y tildar el check “Directory” y dar Next y finalizar en todos los restantes pasos del asistente.



Luego abrimos manualmente el fichero de configuración en el path que se encuentre y allí entre los tags del Directory debemos poner el path donde se encontrarán los ficheros que deseamos que recorra el Foreach



Espero les hay sido de utilidad este nuevo post, saludos a todos!

SSIS – Asignación dinámica de nombres a ficheros de destino de Excel

7 comentarios

Buenos días a todos, en este post voy a explicitar las acciones requeridas para asignar dinámicamente los nombres a los ficheros de destino de Excel (ficheros XLS). Este caso es típico cuando se pretende hacer una exportación diaria de información por ejemplo. Los pasos a seguir son:
1. Crear una variable a nivel de Package de tipo String, la cual va a contener el nombre del fichero de destino.
2. Contar con un Script component en el Data Flow, en el que debemos armar el nombre del fichero concatenando fechas u otras cadenas según sea el nombre que deseamos formar, y posteriormente asignarle dicho nombre a la variable que creamos en el punto 1. (Para ver cómo trabajar con variables en un Script haga click aqui)
3. En la Excel Connection de destino debemos dirigirnos a sus propiedades, Expressions y a la propiedad ConnectionString asignarle la variable creada en el punto 1.


Si son tus primeros pasos en SSIS seguramente no comprenderán demasiado como armar todo el package, si eso sucede les recomiendo que lean los primeros posts en donde explico más detalladamente este tema.
Espero les sirva mi post, y como siempre espero sus comentarios… Saludos!

SQL Server 2008 - Paquete Esencial

0 comentarios

Recientemente Microsoft ha elaborado paquete esencial de tan sólo 40Mb de descarga sobre SQL Server 2008.
La descarga está en inglés y está compuesto por videos, postcast, Case Study, white Papers y otras documentaciones sumamente útiles para los profesionales.
Este paquete es muy interesante porque permite tener una primera impresión bastante acabada de la última versión del Motor de Base de Datos de Microsoft, pero de ninguna manera representa un recurso formativo para aquellos que lo descarguen.



Para descargar el SQL Server 2008 Essential BackPack haga click en el siguiente LINK.

Hacia un nivel de excelencia superior - Certificaciones Microsoft

0 comentarios

Las exigencias a la que nos encontramos sometidos los profesionales en lo que va de este siglo es cada vez mayor, es por ello que no sólo debemos poseer los conocimientos, sino también, cumplir ciertos estándares que el mercado mundial cada vez más globalizado exige. Es por ello que los pasados 17 y 25 de julio de 2008 desde la ciudad de Barcelona, España, he alcanzado mis primeras certificaciones internacionales. Se trata de las certificaciones Microsoft Solution Selling y de Microsoft® .NET Framework 2.0—Application Development Foundation(Exam 70-536). Superar estos examenes no fue nada fácil, pero cuando la empresa en la que trabajas cuenta con una filosofía de mejora continua de sus Ingenieros, donde la calidad profesional y humana es igualmente valorada, y además te brindan todos los medios y su total apoyo se hace mucho más fácil salir adelante. Por ello deseo agradecer a Raona por apoyarme en mi desarrollo profesional y decir que estas certificaciones son sólo el comienzo en mi carrera profesional. La siguiente certificación que intentaré alcanzar será la 70-301 - Managing, Organizing, and Delivering IT Projects by Using Microsoft Solutions Framework 3.0. Pero esa es otra historia... ya tendrán novedades al respecto. Hasta mi próximo post, saludos a todos!!!

SSIS – Usar Data Viewers

0 comentarios

Hola a todos… he regresado con un post “sumamente interesante”… Voy a mostrarles como usar Data Viewers en los flujos de datos. Seguramente se preguntarán para que nos sirven los Data Viewers… nos sirven principalmente para poder observar que datos se están pasando de un componente a otro a través de un flujo de datos y de esta manera poder llevar a cabo un seguimiento más preciso de nuestro proceso.
Veamos cómo se agregan y utilizan los Data Viewers…
Utilizando el mismo ejercicio que expliqué con anterioridad (http://mciacci.blogspot.com/2008/04/ssis-uso-de-condicionales-en.html ) o cualquier otro ejercicio que tengo al menos 2 componentes, debemos hacer lo siguiente:
1. Click derecho sobre la flecha verde que une los componentes, y seleccionamos le opción Edit…

2. Hacemos click en lo opción Data Viewers de la ventana Data Flow Path Editor y posteriormente en el botón Add… de la parte inferior.



3. En la ventana Configure Data Viewer dejamos seleccionado Grid como está por defecto y damos Ok.



4. Damos click en Ok de la ventana Data Flow Path Editor



5. Veremos cómo se agrega un icono de una grilla al costado de la flecha verde, lo que indica que el Data Viewer ha sido agregado.



6. Al ejecutar el proceso veremos que se abre una grilla con los datos que están circulando de un componente a otro. Esto nos servirá para analizar los datos en busca de errores.



Espero les haya servido de ayuda y ante cualquier duda escriban sus comentario

SSIS – Unpivot con un Script

0 comentarios

Muchas veces necesitamos invertir la posición de algunas filas y columnas de entrada para guardarlas en destino. Aclararé un poco más este asunto con un ejemplo, supongamos que tenemos los datos con la siguiente estructura:



Supongamos que por algún motivo necesitamos que esa estructura cambie y adopte la siguiente:



Lo que hemos hecho en la segunda tabla es crear una fila (Row) por cada columna de la primer tabla (excepto la columna ID), entonces por ejemplo, para la primer fila de la primer tabla tenemos 3 filas en la segunda tabla, una para cada columna. Las columnas de la segunda tabla representan lo siguiente:
ID: Código de Cliente, equivalente a la columna ID de la primera tabla.
Columna: indica el número de columna del dato puesto en la columna “Valor” en la primera tabla.
Valor: indica el valor de una determinada columna en la primera tabla.

Ahora…. Como podemos hacer esto en una package de SSIS???
Lo que debemos hacer es agregar en el Data Flow un componente Script de tipo Transformación, posteriormente vincularlo con el componente que le proporcione los datos de entrada y crear los Outputs que necesitamos de salida. Para comprender mejor el asunto, voy a aclarar que lo los Inputs que necesitamos son los campos listados en la primera tabla, mientras que los Outputs son los correspondientes a la segunda tabla. Posteriormente colocaremos el siguiente código dentro del Script:

'Fila para la Columna 1 = Columna Cliente
With Output0Buffer
.AddRow()
'ID es el OUTPUT para el Campo ID y Row.ID es el Input
.ID = Row.ID
.COLUMNA = 1
.VALOR = Row.Cliente
End With
'Fila para la Columna 2 = Columna Categoria
With Output0Buffer
.AddRow()
'ID es el OUTPUT para el Campo ID y Row.ID es el Input
.ID = Row.ID
.COLUMNA = 2
.VALOR = Row.Categoria
End With
'Fila para la Columna 3 = Columna Deuda
With Output0Buffer
.AddRow()
'ID es el OUTPUT para el Campo ID y Row.ID es el Input
.ID = Row.ID
.COLUMNA = 3
.VALOR = Row.Deuda
End With

Damos Ok en el script y lo unimos al destino que corresponda para que se produzca la importaci[on de los datos al destino deseado.
Eso es todo, es más simple de lo que parece… y ya saben, si tienen dudas solo escriban comentarios. Ciao!

SSIS –Deploying Soluciones

0 comentarios

Una vez concluidos y testeados los procesos y demás componentes de una solución, seguramente se necesitará redistribuirlos en otros servidores. Para ello podremos realizar el Deploy de la solución a través del Deploy Utility del SQL Server Business Intelligence Development Studio. Los pasos a seguir son los siguientes:
1. Click botón derecho sobre la Solución, escoger Propiedades.
2. Debemos situarnos en Deployment Utility, y setear la propiedad CreateDeploymentUtility en True. También podemos cambiar el destino de ficheros resultantes modificando la propiedad DeploymentOutputPath.



3. Damos OK.
4. Hacemos click derecho sobre la Solución nuevamente, y escogemos la opción Build. Se compilará la Solución y en caso de no existir errores se deberán crear los ficheros de Deploy en el path especificado en la propiedad DeploymentOutputPathantes mencionada.



5. Si el proceso de Deploy fue exitoso deberá existir en el directorio de Output un fichero con extensión SSISDeploymentManifest. Ejecutando ese Fichero nos aparecerá un asistente para la instalación de los diferentes paquetes, ficheros de configuración y demás componentes de la Solución.

SSIS – Error en Deploy con Ficheros de Configuración Compartidos

0 comentarios

Hace unas semanas, cuando intentaba hacer el deploy de mi solución para redistribuirla me surgió un error muy curioso. El mismo se produce al intentar hacer el deploy de una solución en la que 2 o más packages comparten un mismo fichero de configuración.
Si no conocen que es un fichero de configuración, brevemente les puedo decir que son ficheros por lo general en formato XML que sirven para poder insertar o setear las diferentes propiedades de objetos dentro del Package, por ejemplo se puede definir la ConnectionString de una conexión a BD, el valor de una Variable, entre otros.
El mensaje de error es el siguiente:

System.ApplicationException: Could not copy file "C:\...\xxx.dtsConfig" to the deployment utility output directory "C:\...\xxx\bin\Deployment". ---> System.IO.IOException: The file 'C:\...\...\xxx.dtsConfig' already exists. at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath) at System.IO.File.InternalCopy(String sourceFileName, String destFileName, Boolean overwrite) at Microsoft.DataTransformationServices.Project.DataTransformationsProjectBuilder.CopyFiles(ICollection fileNames, String outputPath) --- End of inner exception stack trace --- at Microsoft.DataTransformationServices.Project.DataTransformationsProjectBuilder.CopyFiles(ICollection fileNames, String outputPath) at Microsoft.DataTransformationServices.Project.DataTransformationsProjectBuilder.CreateDeploymentUtility(IOutputWindow outputWindow)

Investigando en diferentes sitios, libros y materiales pude encontrar una solución “manual” (sí, escucharon bien!!). Dicha solución consiste en crear un archivo de texto, renombrarlo con la extensión .SSISDeploymentManifest e insertar código con estructura XML que enumere todos los packages, ficheros de configuración y demás elementos a redistribuir. Por ejemplo:



Al ejecutar éste archivo, aparecerá el asistente de instalación como normalmente debería suceder.
He leído por algunos foros que el SP2 ya soluciona este bug, aún no he podido comprobarlo, pero ni bien lo haga lo agregaré a mi Blog.
Espero haber sido de ayuda, saludos… nos vemos en la próxima publicación.

Novedades VS 2008 – LINQ

0 comentarios

El presente post está dedicado a mostrarles una de las novedades más importantes a mi criterio que presenta el nuevo Visual Studio 2008. Estoy hablando de Lenguaje Integrado de Consultas o Consultas integradas en los lenguajes, más conocida como LINQ (Language Integrated Query).
Esta nueva funcionalidad permite mayores facilidades de consulta y procesamiento de a todo tipo de fuentes de datos y no sólo a BD relacionales y XML.
LINQ permite que las expresiones de consulta se beneficien de los metadatos ricos, verificación de sintaxis en tiempo de compilación, tipado estático y ayuda IntelliSense que antes estaban disponibles solo para el código imperativo.
LINQ en los lenguajes .NET define un conjunto de operadores de consulta estándar de propósito general que hacen posible que las operaciones de recorrido, filtro y proyección sean expresadas de una manera directa pero declarativa en cualquier lenguaje de programación. Los operadores de consulta estándar permiten aplicar las consultas a cualquier fuente de información basada en IEnumerable.

Para ver algunos ejemplos simples que muestre el potencial de esta nueva funcionalidad se puede mencionar que hasta ahora para buscar algo dentro de un List genérico o un Array List debíamos hacer un IndexOf, sacar en un int el índice y leer esa posición. Ahora haciendo un simple select podemos sacarnos n filas que cumplan n condiciones. Lo propio sucede con datos XML, para sacar algo de un XML debíamos leer todo el documento e ir comparando, pero ya no. Lanzamos contra él una consulta LINQ y listo, ya tenemos lo que queríamos.

En el siguiente ejemplo veremos cómo utilizar LINQ para obtener determinados datos desde un array en una aplicación de consola.

using System;
using System.Query;
using System.Collections.Generic;

class linq_app {
static void Main() {
string[] nombres = { "Carlos", "Pedro", "Juan", "María", "Esteban", "Jorge", "David" };
IEnumerable expr = from s in nombres
where s.Length == 5
orderby s
select s.ToUpper();

foreach (string item in expr)
Console.WriteLine(item);
}
}

Al ejecutar este código obtendremos el siguiente resultado:
David
Jorge
María
Pedro


Si ud. está familiarizado con las sentencias SQL, podrá notar la gran similitud entre una consulta en este lenguaje y el código anterior. A continuación explicaré cada una de las partes de la consulta.

From : variable que accederá a las campos del array en éste caso.
In : lista o array a utilizar como fuente de datos.
Where : filtros o condiciones de la consulta.
Select : campos de la lista o array que deseamos obtener. A diferencia de SQL se ubica al final de la sentencia.

Espero les haya sido de utilidad esta breve introducción a esta nueva funcionalidad del Framework 3.0 .Net. Espero sus comentarios y acotaciones al respecto. Saludos!

SSIS – Usar Package Configuration para parametrizar los paquetes

4 comentarios

SQL Server Integration Services (SSIS) cuenta con una opción sumamente útil a la hora de poner en producción nuestros packages. Dicha funcionalidad es Package Configuration y sirve, básicamente para parametrizar externamente algunos componentes tales como variables, ConnectionStrings para conexiones a Bases de Datos o archivos planos, etc. Esto se lleva a cabo desde archivos externos, comúnmente en formato XML.
Tal vez uno de los usos más frecuentes sea el parametrizar las ConnectionString de las conexiones a las BD tanto de origen como de destino, para de esta manera permitir que el package pueda trabajar con diferentes BD sin necesidad de que éste tenga que ser modificado. Simplemente modificando la cadena de conexión en el archivo de configuración podemos permitir trabajar con diferentes BD.
Los pasos a seguir para utilizar archivos de configuración de packages son los siguientes:
1. Ir al Menú SSIS, elegir la opción Package Configurations…
2. Se abrirá la Ventana de Package Configurations Organizer, en la cual debemos marcar el check que dice Enabled Package Configurations.


3. Hacer clic en el botón Add… tras lo cual se abre una nueva ventana de asistente que nos guiará en el proceso de creación del archivo de configuración. Si hacemos clic en el botón NEXT> ingresamos al primer paso de la creación. Aquí escogeremos el tipo o formato de archivo que deseamos configurar (normalmente lo dejaremos en XML) y luego debemos ingresar el path y el nombre que deseamos que tenga el archivo. Hacemos clic en NEXT> para ir al siguiente paso.


4. En este paso debemos seleccionar las propiedades que deseamos exportar al archivo de configuración. En nuestro caso, suponiendo que tenemos una conexión a una Base de Datos, seleccionaremos la propiedad “connectionstring” de dicha conexión. Damos clic en NEXT> para dirigirnos al último paso.


5. En éste último paso debemos colocar el nombre de configuración y damos click en Finish para culminar este proceso. De esta manera el archivo de configuración ya esta creado y podremos acceder a él para editar la cadena de conexión si lo creemos necesario.


6. Si nos dirigimos al path donde almacenamos el archivo de configuración y lo abrimos podremos ver que se trata de un simple archivo XML. Podemos modificar la connectionString realizando cambios en el lugar adecuado como puede observarse en la siguiente imagen.

SSIS – Uso de Condicionales en componentes Derived Columns

1 comentarios

Quizás se han preguntado alguna vez si es posible el uso de condicionales dentro de un componente de un Data Flow para de esta manera setear el valor de un campo de destino si se cumple determinada condición en un dato de origen. Por ejemplo, si el campo Sexo es igual a 1 (sexo = 1) en el destino debe almacenarse el Valor “Mascuilno”, caso contrario, debe almacenarse el valor “Femenino”. La sintaxis sería la siguiente:
([sexo] == ”1”) ? “Masculino” : “Femenino”
Esta sintaxis puede aplicarse en un componente Derived Column como se puede ver en el siguiente ejemplo. Lo primero que haremos es crear un fichero como el siguiente:


Luego crearemos un nuevo proyecto de Integration Services en SQL Server Business Intelligence Development Studio con el nombre de “Conditional”.
Crearemos las conexiones de origen y destino respectivas como se ven en las siguientes imágenes.






Conexión de Origen – Flat File


Conexión de Destino – Flat File


Insertamos en el Control Flow un Data Flow Task la que llamaremos “Conditional Data Flow task” y dentro de este último insertaremos un Flat File Source, un Derived Column y en Flat File Destination y los relacionaremos como se muestra en la figura siguiente:


En el componente Derived Column pondremos el siguiente código que permitirá realizar la determinación del Sexo del Cliente que se está procesando.


Posteriormente, en el Flat File Destination debemos cambiar el mapeo de campos como se ve en la siguiente figura, para que de esta manera la nueva columna derivada que hemos creado se vincule con la columna “sexo” del fichero de destino.


El resultado del proceso será el siguiente un archivo llamado Cliente_Destino.txt con el siguiente contenido:

SSIS - Uso de Precedence Constraint para direccionar el Flujo de datos

8 comentarios

En éste, mi 3er Post sobre Integration Services voy a mostrarles un ejemplo de cómo desviar el flujo de datos que queremos importar según se cumplan ciertas condiciones. El ejemplo que veremos a continuación, si bien es muy simple, nos servirá para ilustrar una forma de razonamiento muy útil para diversas situaciones.
Supongamos que tenemos una empresa en la que los clientes pueden ser Nacionales e Internacionales. El proceso que debemos realizar debe tomar los datos desde 2 ficheros “.txt” los cuales poseen nombres que los diferencian si se tratan de clientes Nacionales o Extranjeros. El formato del nombre de los ficheros para clientes nacionales es ddmmaaaaNac.txt y para los Internacionales es ddmmaaaaInt.txt y estructuralmente la diferencia es que éstos últimos poseen una columna más denominada “Pais” y por éste motivo deben procesarse por separado, de lo contrario se produciría un error.

Los pasos a seguir en la construcción del ejemplo serán:

1. Creación de Ficheros Origen y Tabla de destino de Datos
2. Creación del Proceso SSIS
3. Ejecución del proceso y análisis de resultados

1. Creación de Ficheros Origen y Tabla de destino de Datos
Para comenzar nuestro ejemplo, debemos crear 4 ficheros “.txt” (ver imagen) en los cuales el separador de columnas es el “tab” y el de filas el “Enter” ({CR}{LF})



Una vez creados estos 4 ficheros con sus respectivos nombres, estructuras y contenidos pasemos a la creación de la tabla destino en SQL Server.
El nombre de la tabla será TablaClientes en la BD Examples y su estructura será la siguiente:



2. Creación del Proceso SSIS
Abriremos el SQL Server Business Intelligence Development Studio donde de crearemos un nuevo proyecto de Integration Services, como nombre le pondremos “Condicional”.
Una vez situados en el Control Flow del Package crearemos 2 variables, la primera se llamará varFileName que contendrá el nombre del fichero que se está procesando en un momento determinado y la variable varFilenationality, la cual albergará los valores “Nac” o “Int” según sea la terminación del archivo procesado. Ambas variables serán de tipo String.



Posteriormente agregaremos las conexiones con los ficheros de Origen y la BD de destino de Datos. Tendremos 2 Flat File Connection, una para los Clientes nacionales y otra para los clientes internacionales, y una OLE DB Connection que se conectará a la BD Examples.
Para las Flat Connections deberemos seleccionar el primer fichero “txt” que creamos con anterioridad según se trate de clientes Nacionales o internacionales, es decir, para la conexión “Clientes Nacionales – Origen” debemos seleccionar como File Name 15102007Nac.txt y para “Clientes Internacionales – Origen” debemos seleccionar como File Name 15102007Int.txt



Además, para estas Flat Connections debemos modificar su propiedad Expressions y colocar como connectionString la variable varFileName. Esto permite que a medida que el foreach recorre los ficheros del directorio, los orígenes de datos obtengan sus datos de los ficheros correspondientes.



Luego, sobre la superficie del Control Flow agregaremos un componente Foreach en el cual definiremos el path que contiene los ficheros y el tipo de ficheros a importar, en nuestro caso “*.txt”



En la opción Variable Mappings del Foreach asignaremos la variable varFileName.



A continuación agregaremos dentro del Foreach un Script Task con el cual podremos determinar si el fichero procesado por el foreach se trata de clientes Nacionales o Internacionales. Renombraremos el script task como “Obtener Ambito Cliente” y lo editaremos. En la opción Script, haremos click en el botón Design Script donde agregaremos el siguiente código:

Imports System
Imports System.Data
Imports System.Math
Imports Microsoft.SqlServer.Dts.Runtime

Public Class ScriptMain

Public Sub Main()

Dim vars As Variables
Dim FileNationality As String
Dim varsNationality As Variables

'asignamos a la variable local "vars" el contenido de la variable varFileName
'que obtiene el nombre del fichero en el Foreach
Dts.VariableDispenser.LockOneForRead("User::varFileName", vars)

'Procesamos la variable varFileName para obtener el ámbito del fichero txt
FileNationality = vars("varFileName").Value.ToString.Substring(vars("varFileName").Value.ToString.Length - 7, 3)

'instanciamos y asignamos a la variable varFileNationality el ámbito obtenido
Dts.VariableDispenser.LockOneForWrite("varFileNationality", varsNationality)
varsNationality("varFileNationality").Value = FileNationality

Dts.TaskResult = Dts.Results.Success
End Sub

End Class


Resumiendo el código, vemos que obtenemos el nombre del fichero que estamos procesando en este momento procesando la variable varFileName, de la cual extraemos el ámbito (Nac o Int) y lo asignamos a la variable varFileNationality. Ésta variable será la que utilizaremos para desviar el flujo de datos hacia un Data Flow u otro más adelante.

El siguiente paso consiste en crear 2 Data Flow, uno llamado “Clientes Nacionales Data Flow Task” y el otro “Clientes Internacionales Data Flow Task”, donde el primero se encargará de importar en la tabla TablaClientes de la BD Examples los datos relativos a los clientes Nacionales y el segundo, los datos de los clientes Internacionales.

Arrastramos sendas flechas desde el Script hasta los Data Flow recientemente creados y el siguiente paso será editar los Precedence Constraint haciendo doble click sobre las mencionadas flechas que unen el Script con los Data Flow.

Editemos el Precedence Constraint que une el Script con el Clientes Nacionales Data Flow Task. Allí debemos cambiar la Evaluation operation a Expression y dentro del campo homónimo escribir:
@[User::varFileNationality] == "Nac"



Damos OK y repetimos la operación para el Precedence Constraint que une el script con el el Clientes Internacionales Data Flow Task, imitamos la configuración anterior pero reemplazando la Expression por la siguiente:
@[User::varFileNationality] == "Int"

El Control Flow quedará de la siguiente manera:



Con esto hemos finalizado el Control Flow, por lo que debemos realizar la funcionalidad de los Data Flow Clientes Nacionales Data Flow Task y Clientes Internacionales Data Flow Task. En ambos debemos agregar un Flat File Source en donde utilizarán las conexiones “Clientes Nacionales – Origen” y “Clientes Internacionales – Origen” respectivamente. Posteriormente debemos agregar un OLE DB Destination que utilizará la conexión ““localhost.Examples” antes creada.



Luego de unir ambos componentes arrastrando la flecha verde del Flat File Source al OLE DB Destination, debemos realizar el mapeo de los campos en éste último.

Cómo podemos ver ambos Data Flow son muy similares, excepto que en el de los clientes Nacionales no disponemos de la columna “Pais” y por lo tanto no podemos mapearla a la Tabla de la BD.



3. Ejecución del proceso y análisis de resultados
El siguiente y último paso será ejecutar el proceso. Si nos paramos sobre el Control Flow de modo tal de ver el Foreach y todo su contenido y ejecutamos el proceso (Presionando F5) veremos cómo según sea el fichero que se está procesando correspondiente a clientes Nacionales o Internacionales, la ejecución se destinará a uno u otro Data Flow de acuerdo a que condición cumpla la variable varFilenationality obtenida.



Si analizamos los datos de la tabla TablaClientes podemos ver que se han importado correctamente los datos y la diferencia entre los clientes Nacionales e Internacionales es que estos últimos poseen un País, mientras que los nacionales tienen el valor NULL en ese campo.

Espero les haya sido de utilidad mi ejemplo y no duden en escribir comentarios ante cualquier duda o inquietud.

Abrir archivos con programa por default (.Net 2.0)

0 comentarios

He retornado, pero esta vez no para escribir sobre SSIS sino sobre una funcionalidad muy sencilla pero no menos interesante del Framework .Net 2.0. Se trata del método Process.Start(), útil para abrir los archivos de cualquier tipo con la aplicación que le corresponde según su extensión. Por ejemplo, si tenemos un archivo con extensión “.doc” o “.docx”, el método se encargará de abrir el archivo con Microsoft Word en la versión que tengamos instalada en nuestra PC. Aquí les pongo un ejemplo tanto para VB como para C#.



Cómo podemos deducir de éste simple código, declaramos que utilizaremos los componentes de System.Diagnostics, luego creamos una proceso llamado “pr”, le asignamos el archivo que deseamos abrir y luego le decimos que comience el proceso. El resultado de este código es que se abrirá el archivo seleccionado con Microsoft Word inmediatamente después de ejecutarse la sentencia pr.Start().

Project REAL

0 comentarios

Buenas a todos los miles de lectores de mi Blog (hay que ser optimista en la vida… jeje). Para todos aquellos que estén dando sus primeros pasos en el mundo de BI (Business Intelligence) les recomiendo que den un vistazo a Project Real. Project Real, como se deduce de su nombre, es el resultado de un esfuerzo conjunto entre Microsoft y numerosos e importantes partners (tales como Unisys y Scalability Experts entre otros) cuyo fin es el proporcionar a las empresas una serie de ejemplos cuasi-reales orientados a instruir sobre la utilización de “Best Practices” para la creación de este tipo de proyectos con MS SQL SERVER 2005.




Si te especializas en ETL o Reporting Services puedes encontrar conceptos y ejemplos muy interesantes al respecto. A continuación les dejo una serie de Links que pueden ser de ayuda.

Project REAL - Home Page
Project REAL - Best practices
Project REAL - Analysis Services Technical Drilldown
Project REAL - Business Intelligence ETL Design Practices

Espero les sean de utilidad estos links. Hasta el próximo post!!!

SSIS – Atributos Históricos tomando fecha desde nombre del Archivo

0 comentarios

He regresado con mi 2º post sobre SSIS, espero el anterior les haya sido de utilidad. Este ejemplo es una continuación del anterior, por ello es importante que hayan respetado la nomenclatura y demás características del mismo. Aquí explicaré como a través de un SCD (Slowly Changing Dimension) podemos llevar un registro histórico de los datos de alumnos ingresados en el post anterior, tomando las fechas que poseen los nombres de los ficheros XLS. Para decirlo más claro, la TablaAlumnos va a contener un registro histórico de los cursos en los que han estado los alumnos, con su fecha de alta y baja respectiva para cada alumno y curso. En caso de que un alumno repita de curso, como los registros de los 2 ficheros XLS serán iguales, el SCD lo detectará y sólo se ingresará una vez.
Al igual que el post anterior, procederé a dividirlo en partes para simplificar su comprensión. Estas son:

1. Modificar los datos en último fichero XLS
2. Agregar componente Script Task para obtener la fecha desde el nombre del fichero
3. Agregar componente SCD
4. Ejecutar el proceso y analizar los resultados

1. Modificar los datos en último fichero XLS
Para que nuestro ejemplo funcione, debemos tomar el último fichero XLS (Alumnos 28022008.xls) y realizarle algunas modificaciones. En realidad debemos hacer sólo 2 modificaciones, a los alumnos con legajo 100 (Perez Mieguel Angel) y 102 (Juarez Martin Alejandro) y reemplazar en la columna “Curso” el valor 3 por el 2. Ello significa que esos alumnos repitieron de curso y las filas para esos 2 alumnos serán exactamente iguales en los archivos Alumnos 28022007.xls y Alumnos 28022008.xls


2. Agregar componente Script Task
El siguiente paso consiste en dirigirnos nuevamente al Package y en el Control Flow dentro del Foreach agregar un componente Script Task desde la ToolBox. Luego de agregado el componente, debemos unir su flecha verde con el Data Flow Task como muestra la siguiente figura.


Dentro de este Script, mediante código VB.Net obtendremos la fecha que figura en el nombre del fichero XLS que esté procesando en ese momento el Foreach.
Antes de mostrarles cómo configurar el Script, vamos a crear una variable llamada “varDate” de tipo DateTime, desde la solapa Variables del IDE.


Una vez creada la variable, hacemos click derecho sobre el Script Task para Editarlo. En la ventana de edición, seleccionamos la opción Script y y cliqueamos el botón Design Script…Esto abrirá una nueva ventana del VS en la cual sede quedar el código siguiente.


' Microsoft SQL Server Integration Services Script Task
' Write scripts using Microsoft Visual Basic
' The ScriptMain class is the entry point of the Script Task.

Imports System
Imports System.Data
Imports System.Math
Imports Microsoft.SqlServer.Dts.Runtime

Public Class ScriptMain

Public Sub Main()
' Declaramos las variables que utilizaremos
Dim vars As Variables
Dim FileDate As String
Dim varsDate As Variables

'asignamos a la variable local "vars" el contenido de la variable varFileName
'que obtiene el nombre del fichero XLS en el Foreach
Dts.VariableDispenser.LockOneForRead("User::varFileName", vars)

'Procesamos la variable varFileName para obtener la fecha del nombre del fichero XLS
'con el formato dd/mm/aaaa
FileDate = vars("varFileName").Value.ToString.Substring(vars("varFileName").Value.ToString.Length - 12, 2) + "/" + _
vars("varFileName").Value.ToString.Substring(vars("varFileName").Value.ToString.Length - 10, 2) + "/" + _
vars("varFileName").Value.ToString.Substring(vars("varFileName").Value.ToString.Length - 8, 4)

'instanciamos y asignamos a la variable varDate la fecha obtenida
Dts.VariableDispenser.LockOneForWrite("varDate", varsDate)
varsDate("varDate").Value = CDate(FileDate)

Dts.TaskResult = Dts.Results.Success
End Sub

End Class



Nótese que el lenguaje utilizado es solamente VB.Net y se puede hacer Debug como cualquier aplicación en VS 2005.
Cerramos la ventana una vez que ingresamos el código, y damos Ok en la ventana de edición de Script Task. Con esto logramos que por cada vez que se recorra un fichero XLS del directorio correspondiente, la variable varDate tome el valor que figura en el nombre del archivo.

3. Agregar componente SCD
Llegó la hora de agregar el SCD (Slowly Changing Dimensión) que nos permitirá agregar los datos en la tabla TablaAlumnos conservando datos históricos. Para ello nos dirigiremos al Data Flow.
Antes de insertar el SCD será conveniente eliminar el OLE DB Destination existente, ya que el nuevo componente se encargará de agregar todos los componentes necesarios al finalizar de configurarlo.
Una vez eliminado el OLE DB Destination procederemos a insertar el SCD desde el ToolBox. Luego uniremos la flecha verde del componente Derived Column con el SCD. Haciendo click derecho, elegiremos la opción Edit…Allí nos aparecerá un asistente que nos permitirá configurar el SCD fácilmente.
En el primer paso daremos click en Next>, mientras que los demás pasos se detallan a continuación:

Paso Select a Dimension Table and keys
En este paso seleccionaremos la tabla, los campos a ser tenidos en cuenta para los cambios y la Key Business que en este caso será el campo Legajo. Damos Next > para ir al siguiente.


Paso Slowly Changing Dimensión Columns
Aquí es donde debemos especificar que columnas y qué tipo de cambios vamos a necesitar. Para nuestro ejemplo seleccionaremos todas las columnas disponibles y su Change Type como Historical Attribute. Damos Next > para ir al siguiente.



Paso Historical Attribute Options
Usaremos “Start and End Dates” para identificar los registros vigentes y expirados. Alli utilizaremos la variable varDate para setear los valores de los campos Registro_valido_desde y Registro_valido_hasta. Damos Next > para ir al siguiente.


Paso Infered Dimension Members
En este paso desmarcaremos el check box “Enable infered member support” y daremos click en Finish > para ir culminar con la configuración del SCD.
Para más información sobre SCD visite
http://msdn2.microsoft.com/en-us/library/ms141662.aspx

Una vez finalizado el asistente, se generarán una serie de componentes automáticamente, los que llevarán a cabo la tarea que nos propusimos al comienzo. El Package se verá de la siguiente manera.



4. Ejecutar el proceso y analizar los resultados
Ya estamos en condiciones de probar el Package, para ello les recomiendo borrar el contenido de la tabla TablaAlumnos para ver más claramente los resultados.
Ejecutemos el proceso presionando F5 y vayamos a ver el contenido de la tabla a la BD. El resultado debería ser el siguiente:


Analizando los datos de la tabla TablaAlumnos, podremos ver que contamos con 2 tipos de alumnos:
a) Los que pasaron todos sus cursos sin problemas año a año. Por ejemplo Legajo 101 Baresi Mateo, si analizamos sus datos veremos que en el año 2006 cursó 1º año, en el 2007 2º año y en el 2008 se encuentra cursando 3º año ya que el campo Registro_valido_hasta se encuentra vacío.


b) Los que repitieron el 2º año. Por ejemplo Legajo 100 Perez Miguel angel y analizando sus datos veremos que sólo tiene 2 registros y no tres como los que no repitieron de año. Veamos por qué. En el año 2006 cursó 1º y en el año 2007 cursó 2º año, el que todavía no ha concluido debido a que ha repetido el mismo.


Analizándolo desde el punto de vista técnico, podemos decir que el SCD detecta en este caso que existen registros exactamente iguales en los archivos Alumnos 28022007.xls y Alumnos 28022008.xls, y por ello no ingresa en la tabla el registro duplicado.
Aquí finaliza mi 2º post, espero les sea de utilidad y por cualquier duda o inquietud solo tienen que agregar comentarios. Saludos a todos!