Compartir vía


Análisis entre inquilinos mediante datos extraídos: aplicación multiinquilino

Se aplica a: Azure SQL Database

En este tutorial, recorrerá un escenario completo de análisis para la implementación de un multiinquilino. En el escenario se explica cómo los análisis pueden permitir a las empresas tomar decisiones inteligentes. Con datos extraídos de la base de datos con particiones, utilice los análisis para obtener información acerca del comportamiento del inquilino, incluido el uso de la aplicación SaaS de ejemplo Wingtip Tickets. Este escenario engloba tres pasos:

  1. Extraer datos de cada base de datos de inquilino en un almacén de análisis.
  2. Optimizar los datos extraídos para el procesamiento de análisis.
  3. Use las herramientas de Business Intelligence para extraer información útil que sirva para tomar decisiones.

En este tutorial, aprenderá a:

  • Crear el almacén de análisis de inquilino para extraer en él los datos.
  • Utilizar trabajos elásticos para extraer datos de cada base de datos de inquilino en el almacén de análisis.
  • Optimizar los datos extraídos (reorganizarlos en un esquema de estrella).
  • Consultar la base de datos de análisis.
  • Usar Power BI para la visualización de datos para resaltar tendencias en los datos de inquilino y hacer recomendaciones para mejoras.

En el diagrama se muestra información general sobre la arquitectura usada para este artículo.

Patrón de análisis de inquilinos sin conexión

Las aplicaciones SaaS que desarrolla tienen acceso a una gran cantidad de datos de inquilino almacenados en la nube. Los datos proporcionan una valiosa fuente de información sobre la operación y el uso de la aplicación y el comportamiento de los inquilinos. Esta información puede guiarle a la hora de desarrollar características, mejorar la facilidad de uso y realizar otras inversiones en la aplicación y la plataforma.

El acceso a los datos para todos los inquilinos es sencillo si todos los datos se encuentran en una única base de datos multiinquilino. Sin embargo, el acceso es más complejo si se distribuyen a escala entre miles de bases de datos. Una forma de reducir la complejidad consiste en extraer los datos en una base de datos de análisis o en un almacenamiento de datos. Después, consulte el almacenamiento de datos para recopilar información de los datos de las entradas de todos los inquilinos.

En este tutorial se presenta un escenario de análisis completo para esta aplicación SaaS de ejemplo. En primer lugar, se usan trabajos elásticos para programar la extracción de datos de cada base de datos de inquilino. Los datos se envían a un almacén de análisis. El almacén de análisis puede utilizar la base de datos de Azure SQL o Azure Synapse Analytics. Para la extracción de datos a gran escala, se recomienda Azure Data Factory.

A continuación, los datos agregados se dividen en un conjunto de tablas en un esquema de estrella. Las tablas constan de una tabla de hechos central más tablas de dimensiones relacionadas:

  • La tabla de hechos central del esquema de estrella contiene datos de las entradas.
  • Las tablas de dimensiones contienen datos sobre lugares, eventos, clientes y fechas de compra.

De forma conjunta, las tablas centrales y de dimensiones permiten realizar un procesamiento analítico eficaz. El esquema de estrella usado en este tutorial se muestra en la siguiente imagen:

En el diagrama de base de datos se muestran cuatro objetos de base de datos conectados a un objeto de base de datos central.

Por último, se consultan las tablas de un esquema de estrella. Los resultados de la consulta se muestran visualmente para resaltar la información sobre el comportamiento de los inquilinos y el uso que estos hacen de la aplicación. Con este esquema de estrella, puede ejecutar consultas que ayudan a encontrar elementos similares a los siguientes:

  • Quién compra las entradas y desde qué lugar.
  • Patrones y tendencias ocultos en estas áreas:
    • Las ventas de entradas.
    • La popularidad relativa de cada lugar.

Saber con qué coherencia cada inquilino usa el servicio brinda una oportunidad para crear planes de servicio destinados a satisfacer sus necesidades. En este tutorial se proporcionan ejemplos básicos de información que puede deducirse de los datos de inquilino.

Configurar

Requisitos previos

Para completar este tutorial, asegúrese de cumplir estos requisitos previos:

Creación de datos para la demostración

En este tutorial, se realiza un análisis de los datos de ventas de entradas. En el paso actual, genera datos sobre las entradas para todos los inquilinos. Más adelante, estos datos se extraen para los análisis. Asegúrese de haber aprovisionado el lote de los inquilinos como se describió anteriormente, para que tenga una cantidad significativa de datos. Una cantidad de datos lo suficientemente grande puede exponer un intervalo de patrones de compra de entradas distintos.

  1. En PowerShell ISE, abra …\Learning Modules\Operational Analytics\Tenant Analytics\Demo-TenantAnalytics.ps1 y defina este valor:
    • $DemoScenario = 1 Purchase tickets for events at all venues
  2. Presione F5 para ejecutar el script y crear un historial de compra de entradas para cada evento en cada lugar. El script se ejecuta durante varios minutos para generar decenas de miles de entradas.

Implementación del almacén de análisis

A menudo, hay numerosas bases de datos transaccionales y con particiones que juntas contienen todos los datos de inquilino. Debe agregar los datos de inquilino de la base de datos con particiones en un solo almacén de análisis. La agregación permite realizar una consulta eficaz de los datos. En este tutorial, se usa una base de datos de Azure SQL Database para almacenar los datos agregados.

En los pasos siguientes, se implementa el almacén de análisis, que se denomina tenantanalytics. También va a implementar tablas predefinidas que se rellenan más adelante en el tutorial:

  1. En PowerShell ISE, abra …\Learning Modules\Operational Analytics\Tenant Analytics\Demo-TenantAnalytics.ps1.
  2. Establezca la variable $DemoScenario en el script para que coincida con el almacén de análisis elegido. Con fines de aprendizaje, se recomienda usar la base de datos sin almacén de columnas.
    • Para usar SQL Database sin almacén de columnas, establezca $DemoScenario = 2.
    • Para usar SQL Database con almacén de columnas, establezca $DemoScenario = 3.
  3. Presione F5 para ejecutar el script de demostración (que llama al script Deploy-TenantAnalytics<XXX>.ps1) que crea el almacén de análisis de inquilino.

Ahora que ya ha implementado la aplicación y la ha llenado de datos de inquilino interesantes, use SQL Server Management Studio (SSMS) para conectar los servidores tenants1-mt-<User> y catalog-mt-<User> con el nombre de usuario developer y la contraseña P@ssword1.

architectureOverView

En el Explorador de objetos, siga estos pasos:

  1. Expanda el servidor tenants1-mt-<Usuario> .
  2. Expanda el nodo Bases de datos y vea la base de datos tenants1 que contiene varios inquilinos.
  3. Expanda el servidor catalog-mt-<Usuario> .
  4. Verifique que puede ver el almacén de análisis y la base de datos jobaccount.

Expanda el almacén de análisis para ver los siguientes elementos de la base de datos en el Explorador de objetos de SSMS:

  • Las tablas TicketsRawData y EventsRawData contienen datos sin procesar extraídos de las bases de datos de inquilino.
  • Las tablas del esquema de estrella son fact_Tickets, dim_Customers, dim_Venues, dim_Events y dim_Dates.
  • El procedimiento almacenado sp_ShredRawExtractedData se usa para rellenar las tablas del esquema de estrella a partir de las tablas de datos sin procesar.

En la captura de pantalla se muestra el Explorador de objetos SSMS para el nodo del almacén de análisis, incluidas las tablas, las vistas y los nodos.

Extracción de datos

Creación de grupos de destino

Antes de continuar, asegúrese de haber implementado la cuenta de trabajo y la base de datos jobaccount. En la siguiente serie de pasos, se usan trabajos elásticos para extraer datos de cada base de datos de inquilinos con particiones y para almacenar los datos en el almacén de análisis. Después, el segundo trabajo desglosa los datos y los almacena en tablas en el esquema de estrella. Estos dos trabajos se ejecutan en dos grupos de destino distintos, denominados TenantGroup y AnalyticsGroup. El trabajo de extracción se ejecuta en el grupo TenantGroup, que contiene todas las bases de datos de inquilino. El trabajo de desglose se ejecuta en el grupo AnalyticsGroup, que contiene solo el almacén de análisis. Cree los grupos de destino mediante los pasos siguientes:

  1. En SSMS, conéctese a la base de datos jobaccount en catalog-mt-<Usuario>.
  2. En SSMS, abra …\Learning Modules\Operational Analytics\Tenant Analytics\ TargetGroups.sql
  3. Modifique la variable @User en la parte superior del script y reemplace <User> por el valor de usuario utilizado cuando implementó la aplicación SaaS de base de datos multiinquilino Wingtip Tickets.
  4. Presione F5 para ejecutar el script que crea los dos grupos de destino.

Extracción de datos sin procesar de todos los inquilinos

Las transacciones pueden ocurrir con más frecuencia para datos de entradas y clientes que para datos de eventos y lugares. Por tanto, considere la posibilidad de extraer los datos sobre las entradas y los clientes por separado y con más frecuencia de la que extrae los datos sobre eventos y lugares. En esta sección, se van a definir y programar dos trabajos independientes:

  • Extraer los datos de las entradas y los clientes.
  • Extraer los datos de los eventos y los lugares.

Cada trabajo extrae sus datos y los introduce en el almacén de análisis. Ahí, un trabajo independiente desglosa los datos extraídos en el esquema de estrella de análisis.

  1. En SSMS, conéctese a la base de datos jobaccount en el servidor catalog-mt-<Usuario>.
  2. En SSMS, abra ...\Learning Modules\Operational Analytics\Tenant Analytics\ExtractTickets.sql.
  3. Modifique @User en la parte superior del script y reemplace <User> por el nombre de usuario utilizado cuando implementó la aplicación SaaS de base de datos multiinquilino Wingtip Tickets.
  4. Presione F5 para ejecutar el script que crea y ejecuta el trabajo que extrae los datos de las entradas y los clientes de cada base de datos de inquilino. El trabajo guarda los datos en el almacén de análisis.
  5. Consulte la tabla TicketsRawData en la base de datos tenantanalytics, para asegurarse de que la tabla se rellena con la información de las entradas de todos los inquilinos.

Repita los pasos anteriores, excepto esta sustitución de tiempo de \ExtractTickets.sql por \ExtractVenuesEvents.sql en el paso 2.

Si el trabajo se ejecuta correctamente, se rellena la tabla EventsRawData del almacén de análisis con información nueva de los eventos y los lugares de todos los inquilinos.

Reorganización de datos

Desglose de los datos extraídos para rellenar las tablas de un esquema de estrella

El paso siguiente consiste en desglosar los datos sin procesar extraídos en un conjunto de tablas que se optimizan para las consultas de análisis. Se utiliza un esquema de estrella. Una tabla de hechos central contiene registros de ventas de entradas individuales. Las tablas de dimensiones se rellenan con datos sobre lugares, eventos, clientes y fechas de compra.

En esta sección del tutorial, va a definir y ejecutar un trabajo que combina los datos sin procesar extraídos con los datos de las tablas de un esquema de estrella. Cuando finaliza el trabajo de combinación, se eliminan los datos sin procesar, dejando las tablas listas para que se rellenen con el próximo trabajo de extracción de datos de inquilino.

  1. En SSMS, conéctese a la base de datos jobaccount en catalog-mt-<Usuario>.
  2. En SSMS, abra …\Learning Modules\Operational Analytics\Tenant Analytics\ShredRawExtractedData.sql.
  3. Presione F5 para ejecutar el script con el que se define un trabajo que llama al procedimiento almacenado sp_ShredRawExtractedData en el almacén de análisis.
  4. Deje tiempo suficiente para que el trabajo se ejecute correctamente.
    • Consulte la columna Lifecycle de la tabla jobs.jobs_execution para comprobar el estado del trabajo. Asegúrese de que el trabajo se ha completado correctamente antes de continuar. Una ejecución satisfactoria muestra datos similares a los del siguiente gráfico:

En la captura de pantalla se muestra el resultado correcto de la ejecución del procedimiento sp_ShredRawExtractedData.

Exploración de datos

Visualización de datos de inquilino

Los datos de las tablas de un esquema de estrella proporcionan todos los datos de ventas de entradas necesarios para el análisis. Para facilitar la visualización de tendencias en grandes conjuntos de datos, necesita una representación gráfica. En esta sección, va a aprender a usar Power BI para manipular y visualizar los datos de inquilino que extrajo y organizó.

Siga estos pasos para conectarse a Power BI e importar las vistas creadas anteriormente:

  1. Lance Power BI Desktop.

  2. En la cinta de opciones de Inicio, seleccione Obtener datos y, después, seleccione Más… del menú.

  3. En la ventana Obtener datos, seleccione Azure SQL Database.

  4. En la ventana de inicio de sesión de la base de datos, escriba el nombre del servidor (catalog-mt-<Usuario>.database.windows.net). Seleccione Importar en Modo Conectividad de datos y después haga clic en Aceptar.

    En la captura de pantalla se muestra el cuadro de diálogo de la base de datos de SQL Server, desde donde puede acceder al servidor y la base de datos.

  5. Seleccione Base de datos en el panel izquierdo y escriba los valores de user name = developer y password = P@ssword1. Haga clic en Conectar.

    En la captura de pantalla se muestra el cuadro de diálogo de la base de datos de SQL Server, desde donde puede especificar un nombre de usuario y una contraseña.

  6. En el panel Navegador, debajo de la base de datos de análisis, seleccione las tablas del esquema de estrella: fact_Tickets, dim_Events, dim_Venues, dim_Customers y dim_Dates. Después seleccione Cargar.

Felicidades. Ha cargado los datos correctamente en Power BI. Ahora puede empezar a explorar visualizaciones interesantes para ayudar a obtener información sobre los inquilinos. Después, se ofrece orientación sobre cómo los análisis pueden permitirle proporcionar recomendaciones basadas en datos al equipo empresarial de Wingtip Tickets. Las recomendaciones pueden ayudarle a optimizar el modelo de negocio y la experiencia del cliente.

Primero debe analizar los datos de ventas de entradas para ver la variación del uso entre los distintos lugares. Seleccione las opciones siguientes en Power BI para trazar un gráfico de barras del número total de entradas vendidas en cada lugar. Debido a la variación aleatoria del generador de entradas, los resultados pueden ser diferentes.

En la captura de pantalla se muestra una visualización de Power BI y controles para la visualización de datos a la derecha.

El gráfico anterior confirma que el número de entradas vendidas en cada lugar varía. Los lugares que venden más entradas usan su servicio con mayor frecuencia que aquellos que venden menos. En este caso, puede haber una oportunidad de adaptar la asignación de recursos a las diferentes necesidades de los inquilinos.

Puede analizar aún más los datos para ver cómo varían las ventas de entradas con el paso del tiempo. Seleccione las opciones siguientes en Power BI para trazar un gráfico de barras del número total de entradas vendidas cada día durante un período de sesenta días.

En la captura de pantalla se muestra una visualización de Power BI titulada Ticket Sale Distribution (Distribución de venta de entradas) comparada con Sale Day (Día de ventas).

En el gráfico anterior se muestra que las ventas de entradas presentan picos en algunos lugares. Estos picos refuerzan la idea de que algunos lugares pueden estar consumiendo recursos del sistema de manera desproporcionada. Hasta ahora no hay ningún patrón obvio de cuándo se producen los picos.

Después, puede que quiera indagar más en la importancia de los días en que se registran los picos de ventas. ¿Cuándo se producen estos picos después de que las entradas salen a la venta? Para obtener un gráfico de las entradas vendidas al día, seleccione las siguientes opciones en Power BI.

SaleDayDistribution

En el gráfico anterior se refleja que algunos lugares venden muchas entradas el primer día de venta. En cuanto las entradas salen a la venta en estos lugares, parece haber una desenfrenada demanda. Tan intensa actividad en algunos lugares puede repercutir en el servicio de otros inquilinos.

Puede profundizar en los datos de nuevo para ver si tal desenfrenada demanda se produce para todos los eventos celebrados en estos lugares. En los gráficos anteriores, observó que Contoso Concert Hall vende muchas entradas y que Contoso también registra un pico de ventas de entradas en determinados días. Practique con las opciones de Power BI para trazar un gráfico de las ventas de entradas acumulativas de Contoso Concert Hall, centrándose en las tendencias de ventas de cada uno de sus eventos. ¿Todos los eventos siguen el mismo patrón de venta?

ContosoSales

En el gráfico anterior de Contoso Concert Hall, se refleja que la desenfrenada demanda no se registra para todos los eventos. Practique con las opciones de filtro para ver las tendencias de venta de otros lugares.

La información de los patrones de venta de entradas pueden permitir a Wingtip Tickets optimizar su modelo de negocio. En lugar de aplicar los mismos cargos a todos los inquilinos, quizá Wingtip debería introducir niveles de servicio con distintos tamaños de proceso. A los lugares más grandes que necesitan vender más entradas al día se les podría ofrecer un nivel superior con un contrato de nivel de servicio (SLA) de categoría superior. Estos lugares podrían tener sus bases de datos agrupadas con límites de recursos por base de datos más altos. Cada nivel de servicio podría tener una asignación de ventas por hora, con tarifas adicionales por exceder la asignación. Los lugares más grandes que tienen intensas actividades de ventas se beneficiarían de los niveles más altos, y Wingtip Tickets puede monetizar su servicio con mayor eficacia.

Mientras tanto, algunos clientes de Wingtip Tickets se quejan de que tienen dificultades para vender las suficientes entradas como para cubrir el costo del servicio. Quizá en esta información se ofrece la oportunidad de impulsar las ventas de entradas para los lugares que presentan déficit de rendimiento. Un aumento de las ventas aumentaría el valor percibido del servicio. Haga clic con el botón derecho en fact_Tickets y seleccione Nueva medida. Escriba la siguiente expresión para la nueva medida denominada AverageTicketsSold:

AverageTicketsSold = DIVIDE(DIVIDE(COUNTROWS(fact_Tickets),DISTINCT(dim_Venues[VenueCapacity]))*100, COUNTROWS(dim_Events))

Seleccione las siguientes opciones de visualización para obtener un gráfico del porcentaje de entradas vendidas en cada lugar para determinar su éxito relativo.

analyticsViews

En el gráfico anterior se refleja que, aunque la mayoría de los lugares venden más del 80 % de las entradas, algunos se esfuerzan por llegar a más de la mitad del aforo. Practique con los valores Well para seleccionar los porcentajes máximo y mínimo de las entradas vendidas en cada lugar.

Anteriormente, profundizó en sus análisis para detectar que las ventas de entradas tienden a seguir patrones predecibles. Esta conclusión puede permitir a Wingtip Tickets ayudar a los lugares que presentan un déficit de rendimiento a impulsar las ventas de entradas mediante la recomendación de precios dinámicos. Este hecho podría brindar una oportunidad para emplear técnicas de aprendizaje automático para predecir ventas de entradas de cada evento. También se pueden realizar predicciones de la repercusión que la oferta de descuentos en las ventas de entradas puede tener en los ingresos. Power BI Embedded puede integrarse en una aplicación de administración de eventos. La integración de podría ayudar a visualizar las ventas previstas y el efecto de diferentes descuentos. La aplicación podría ayudar a diseñar un descuento óptimo para aplicarlo directamente desde la pantalla de análisis.

Ha observado las tendencias de los datos de inquilino de la aplicación SaaS de base de datos multiinquilino Wingtip Tickets. Puede contemplar otras formas en que la aplicación puede informar de las decisiones empresariales a los proveedores de aplicaciones SaaS. De esta forma, los proveedores pueden satisfacer mejor las necesidades de sus inquilinos. Se espera que este tutorial le haya proporcionado todas las herramientas necesarias para realizar análisis de datos de inquilino para permitir que las empresas tomen decisiones basadas en datos.

Pasos siguientes

En este tutorial, ha aprendido a:

  • Implementar una base de datos de análisis de inquilino con tablas de un esquema de estrella predefinidas
  • Utilizar trabajos elásticos para extraer datos de todas las bases de datos de inquilinos
  • Combinar los datos extraídos en tablas en un esquema de estrella diseñado para el análisis
  • Consultar una base de datos de análisis
  • Usar Power BI para la visualización de datos para observar tendencias en los datos de inquilino

Felicidades.

Recursos adicionales

Otros tutoriales basados en la aplicación SaaS de Wingtip.