Compartir vía


Información general sobre las consultas elásticas de Azure SQL Database (versión preliminar)

Se aplica a:Azure SQL Database

La característica de consulta elástica (en versión preliminar) permite ejecutar una consulta de Transact-SQL (T-SQL) que abarca varias bases de datos de Azure SQL Database. Permite realizar consultas entre bases de datos para acceder a tablas remotas, así como conectar herramientas de Microsoft y de terceros (Excel, Power BI, Tableau, etc.) para realizar consultas en capas de datos con varias bases de datos. Con esta característica, puede escalar consultas horizontalmente a capas de datos de gran tamaño y visualizar los resultados en informes de inteligencia empresarial (BI).

Razones para usar consultas elásticas

Azure SQL Database

Realice consultas entre bases de datos en Azure SQL Database completamente en T-SQL. Esto permite realizar consultas de solo lectura en bases de datos remotas y proporciona una opción para que los clientes actuales de SQL Server migren las aplicaciones que usan nombres de tres y cuatro partes, o bien un servidor vinculado a la base de datos SQL.

Disponible en todos los niveles de servicio

La consulta elástica se admite en todos los niveles de servicio de Azure SQL Database. Consulte más adelante la sección Limitaciones de la versión preliminar, que trata sobre las limitaciones del rendimiento para los niveles de servicio inferiores.

Inserción de parámetros en bases de datos remotas

Ahora las consultas elásticas pueden insertar parámetros SQL en las bases de datos remotas para su ejecución.

Ejecución de un procedimiento almacenado

Ejecute llamadas a procedimientos almacenados remotos o funciones remotas mediante sp_execute_remote.

Flexibilidad

Las tablas externas con consulta elástica pueden hacer referencia a tablas remotas con un nombre de tabla o un esquema diferente.

Escenarios de consulta elástica

El objetivo es facilitar escenarios de consulta en los que varias bases de datos aportan filas a un único resultado global. El usuario o la aplicación pueden componer la consulta directamente, o también se puede conseguir de forma indirecta mediante las herramientas que están conectadas a la base de datos. Esto resulta especialmente útil al crear informes, usar herramientas de integración de datos o BI comercial, o cualquier aplicación que no se pueda cambiar. Con una consulta elástica, puede consultar varias bases de datos por medio de la conocida experiencia de conectividad de SQL Server en herramientas como Excel, Power BI, Tableau o Cognos. Una consulta elástica facilita el acceso a toda una colección de bases de datos a través de las consultas emitidas por SQL Server Management Studio o Visual Studio. Asimismo, permite las consultas entre bases de datos desde Entity Framework u otros entornos de ORM. En la Figura 1 se muestra un escenario donde una aplicación en la nube existente (que usa la biblioteca de cliente de bases de datos elásticas) se compila en una capa de datos escalada horizontalmente y se usa una consulta elástica para informes entre bases de datos.

Figura 1 Consulta usada en la capa de datos de escala horizontal

Captura de pantalla de la consulta de Elastic usada en el nivel de datos escalado horizontalmente.

Los escenarios de clientes para la consulta elástica se caracterizan por las siguientes topologías:

  • creación de particiones verticales: consultas entre bases de datos (topología 1): los datos se particionan verticalmente entre varias bases de datos en un nivel de datos. Normalmente, los distintos conjuntos de tablas residen en bases de datos diferentes. Esto significa que el esquema es diferente en las distintas bases de datos. Por ejemplo, todas las tablas de inventario se encuentran en una base de datos mientras que todas las relacionadas con la contabilidad se encuentran en otra. En los casos de uso habituales con esta topología, se requiere uno para realizar una consulta o compilar informes en todas las tablas de varias bases de datos.

  • Creación de partición horizontal: particionamiento (Topología 2): los datos se particionan en horizontal para distribuir las filas en una capa de datos de escala horizontal. Con este enfoque, el esquema es idéntico en todas las bases de datos participantes. Este enfoque también se denomina particionamiento. El particionamiento se puede realizar y administrar mediante 1) las bibliotecas de herramientas de bases de datos elásticas o 2) el particionamiento automático. Se usa una consulta elástica para realizar consultas o compilar informes en muchas particiones. Las particiones suelen ser bases de datos dentro de un grupo elástico. Puede considerar la consulta elástica como una forma eficaz de consultar todas las bases de datos de un grupo elástico a la vez, siempre que las bases de datos compartan el esquema común.

Nota:

La consulta elástica funciona mejor en escenarios de informes en los que la mayor parte del procesamiento (filtrado, agregación) se puede realizar en el origen externo. No es adecuado para las operaciones ETL en las que se transfiere una gran cantidad de datos desde bases de datos remotas. Para grandes cargas de trabajo de informes o escenarios de almacenamiento de datos con consultas más complejas, considere también usar Azure Synapse Analytics.

Particionamiento vertical: consultas entre bases de datos

Para empezar a codificar, consulte la introducción a la consulta entre bases de datos (creación de particiones verticales).

Se puede usar una consulta elástica para que los datos de una base de datos de SQL Database estén disponibles para otras bases. Esto permite que las consultas desde una base de datos hagan referencia a las tablas de cualquier otra base de datos remota en SQL Database. El primer paso consiste en definir un origen de datos externo para cada base de datos remota. El origen de datos externo se define en la base de datos local desde la que desee obtener acceso a las tablas que residen en la base de datos remota. No es necesario realizar cambios en la base de datos remota. En los escenarios típicos de particionamiento vertical en los que las diferentes bases de datos tienen esquemas distintos, se pueden usar consultas elásticas para implementar casos de uso habituales, como el acceso a datos de referencia y la consulta entre bases de datos.

Importante

Debe poseer el permiso ALTER ANY EXTERNAL DATA SOURCE. Este permiso está incluido en el permiso ALTER DATABASE. Se requieren permisos ALTER ANY EXTERNAL DATA SOURCE para referirse al origen de datos subyacente.

Datos de referencia: la topología se usa para la administración de datos de referencia. En la ilustración siguiente, se conservan dos tablas (T1 y T2) con datos de referencia en una base de datos dedicada. Con una consulta elástica, ahora puede acceder a las tablas T1 y T2 de forma remota desde otras bases de datos, como se muestra en la ilustración. Use la topología 1 si las tablas de referencia son pequeñas o si las consultas remotas en la tabla de referencia tienen predicados selectivos.

Ilustración 2 Particionamiento vertical: usar una consulta elástica para consultar datos de referencia

Captura de pantalla de la creación de particiones verticales: uso de consultas elásticas para consultar datos de referencia.

Consultas entre bases de datos: las consultas elásticas hacen posibles los casos de uso que requieren realizar consultas entre varias bases de datos en SQL Database. En la figura 3 se muestran cuatro bases de datos distintas: CRM, Inventory, HR y Products. Las consultas realizadas en una de las bases de datos también necesitan acceder a una de las otras bases de datos o a todas ellas. Mediante una consulta elástica, puede configurar la base de datos para este caso ejecutando unas pocas instrucciones DDL sencillas en cada una de las cuatro bases de datos. Después de esta configuración única, el acceso a una tabla remota es tan sencillo como hacer referencia a una tabla local desde las consultas T-SQL o las herramientas de BI. Este enfoque se recomienda si las consultas remotas no devuelven resultados grandes.

Ilustración 3 Particionamiento vertical: usar una consulta elástica para consultar en varias bases de datos

Captura de pantalla de la creación de particiones verticales: uso de consultas elásticas para realizar consultas en varias bases de datos.

Con los siguientes pasos se configuran consultas de bases de datos elásticas para escenarios de particionamiento vertical que requieren acceso a una tabla ubicada en bases de datos remotas en SQL Database con el mismo esquema:

Después de ejecutar las instrucciones DDL, puede acceder a la tabla remota mytable como si fuera una tabla local. Azure SQL Database abre automáticamente una conexión con la base de datos remota, procesa la solicitud en la base de datos remota y devuelve los resultados.

Particiones horizontales (particionamiento)

El uso de una consulta elástica para realizar tareas de informes en una capa de datos particionada, es decir, con particiones horizontales, requiere un mapa de particiones de bases de datos elásticas para representar las bases de datos de la capa de datos. Normalmente, se usa un solo mapa de particiones en este escenario y una base de datos dedicada con funcionalidades de consulta elástica (nodo principal) sirve de punto de entrada para las consultas de informes. Esta base de datos dedicada es la única que necesita acceder al mapa de particiones. La ilustración 4 muestra esta topología y su configuración con la base de datos de consulta elástica y el mapa de particiones. Para obtener más información acerca de la biblioteca de cliente de bases de datos elásticas y crear mapas de particiones, consulte Administración de mapas de particiones.

Ilustración 4 Particionamiento horizontal: usar una consulta elástica para informes en capas de datos particionadas

Captura de pantalla de la creación de particiones horizontales: uso de consultas elásticas para la creación de informes sobre niveles de datos particionados.

Nota:

La base de datos de consulta elástica (nodo principal) puede ser una independiente o la misma que hospeda el mapa de particiones. Independientemente de la configuración que elija, asegúrese de que el nivel de servicio y el tamaño de proceso de esa base de datos son lo suficientemente altos como para controlar el número esperado de solicitudes de inicio de sesión o consulta.

Con los siguientes pasos, se configuran consultas de bases de datos elásticas para escenarios de particionamiento horizontal que requieren acceso a un conjunto de tablas ubicadas, por lo general, en varias bases de datos remotas en SQL Database:

Una vez realizados estos pasos, puede acceder a la tabla con particiones horizontales mytable como si fuera una tabla local. Azure SQL Database abre automáticamente varias conexiones paralelas con las bases de datos remotas donde se almacenan las tablas, procesa las solicitudes en las bases de datos remotas y devuelve los resultados. Obtenga más información sobre los pasos necesarios para el escenario de particionamiento horizontal en Consulta de bases de datos elásticas para particionamiento horizontal.

Para empezar a codificar, consulte Introducción a las consultas elásticas para particionamiento horizontal (particionamiento).

Importante

La ejecución correcta de una consulta elástica en un conjunto grande de bases de datos depende en gran medida de la disponibilidad de cada una de las bases de datos durante la ejecución de la consulta. Si una de las bases de datos no está disponible, se produce un error en toda la consulta. Si tiene previsto consultar cientos o miles de bases de datos a la vez, asegúrese de que la aplicación cliente tiene insertada una lógica de reintento, o considere la posibilidad de aprovechar los trabajos elásticos y consultar subconjuntos más pequeños de bases de datos, consolidando los resultados de cada consulta en un único destino.

Consultas T-SQL

Una vez que defina los orígenes de datos externos y las tablas externas, puede usar cadenas de conexión de SQL Server normales para conectarse a las bases de datos en las que definió las tablas externas. A continuación, puede ejecutar instrucciones T-SQL sobre las tablas externas en esa conexión con las limitaciones descritas más adelante en este artículo. Puede encontrar más información y ejemplos de consultas T-SQL en los artículos de documentación para creación de particiones horizontales y creación de particiones verticales.

Conectividad para herramientas

Puede usar cadenas de conexión de SQL Server normales para conectar sus aplicaciones y herramientas de integración de datos o de BI a bases de datos con tablas externas. Asegúrese de que SQL Server se admite como origen de datos para la herramienta. Una vez conectadas, consulte la base de datos de consulta elástica y las tablas externas de esa base de datos como haría con cualquier otra base de datos de SQL Server a la que se conecte con su herramienta.

Importante

Las consultas elásticas solo son compatibles al conectarse con la autenticación de SQL Server.

Coste

La consulta elástica se incluye en el costo de Azure SQL Database. Se admiten topologías en las que las bases de datos remotas se encuentran en un centro de datos diferente al punto de conexión de consulta elástica, pero la salida de datos de las bases de datos remotas cobra periódicamente tarifas de Azure.

Limitaciones de vista previa

  • La ejecución de la primera consulta elástica puede tardar hasta unos minutos en recursos más pequeños y del nivel de servicio Estándar y De uso general. Esta vez es necesario cargar la funcionalidad de consulta elástica; el rendimiento de carga mejora con niveles de servicio y tamaños de proceso más altos.

  • Todavía no se admite la creación de scripts de orígenes de datos externos o tablas externas de SSMS o SSDT.

  • Import/Export para SQL Database aún no admite orígenes de datos externos ni tablas externas. Si necesita usar Importación/Exportación, quite estos objetos antes de exportar y después vuelva a crearlos después de importar.

  • Actualmente, la consulta elástica solo es compatible con el acceso de solo lectura a tablas externas. No obstante, puede usar la funcionalidad completa de T-SQL en la base de datos donde se define la tabla externa. Esto puede ser útil para, por ejemplo, conservar los resultados temporales mediante, por ejemplo, SELECT <column_list> INTO <local_table>, o para definir procedimientos almacenados en la base de datos de consultas elásticas que hacen referencia a tablas externas.

  • A excepción de nvarchar(max), los tipos LOB (incluidos los tipos espaciales) no se admiten en las definiciones de tabla externa. Como solución alternativa, puede crear una vista en la base de datos remota que convierta el tipo LOB en nvarchar(max), definir la tabla externa sobre la vista en lugar de la tabla base y luego volver a convertirla al tipo LOB original en sus consultas.

  • Las columnas de tipo de datos nvarchar(max) en el conjunto de resultados deshabilitan técnicas avanzadas de procesamiento por lotes usadas en la implementación de consultas elásticas y podrían afectar al rendimiento de la consulta para un orden de magnitud, o incluso dos órdenes de magnitud en casos de uso no canónicos en los que se transfiere una gran cantidad de datos no agregados como resultado de la consulta.

  • Actualmente no se admiten estadísticas de columna con tablas externas. Se admiten las estadísticas de las tablas, pero se deben crear manualmente.

  • No se admiten cursores para tablas externas en Azure SQL Database.

  • Las consultas elásticas solo funcionan con Azure SQL Database. No se puede usar para consultar una instancia de SQL Server.

  • Actualmente, los vínculos privados no se admiten con la consulta elástica para esas bases de datos que son destinos de orígenes de datos externos.