Uso de procedimientos almacenados para grupos de SQL dedicados en Azure Synapse Analytics
En este artículo se proporcionan sugerencias para desarrollar soluciones del grupo de SQL dedicado mediante la implementación de procedimientos almacenados.
Qué esperar
El grupo de SQL dedicado admite muchas de las características de T-SQL que se usan en SQL Server. Más importante aún, hay características específicas de escalabilidad horizontal que puede utilizar para maximizar el rendimiento de la solución.
Además, para ayudarle a mantener la escala y el rendimiento del grupo de SQL dedicado, hay características y funcionalidades adicionales que tienen diferencias de comportamiento.
Introducción a los procedimientos almacenados
Los procedimientos almacenados son una manera excelente para encapsular el código SQL, que se almacena cerca de los datos del grupo de SQL dedicado. Los procedimientos almacenados también ayudan a los desarrolladores a encapsular el código en unidades administrables para modularizar sus soluciones, de tal manera que facilitan una mayor reutilización del código. Cada procedimiento almacenado también puede aceptar parámetros para que sean todavía más flexibles.
El grupo de SQL dedicado proporciona una implementación optimizada y simplificada de procedimientos almacenados. La diferencia más importante en comparación con SQL Server es que el procedimiento almacenado no es código compilado previamente.
En general, en el almacenamiento de datos, el tiempo de compilación es corto en comparación con el tiempo necesario para ejecutar consultas en grandes volúmenes de datos. Es más importante asegurarse de que el código del procedimiento almacenado esté optimizado correctamente para consultas grandes.
Sugerencia
El objetivo es ahorrar horas, minutos y segundos, no milisegundos. Por lo tanto, resulta útil pensar en los procedimientos almacenados como contenedores para la lógica SQL.
Si el grupo de SQL dedicado ejecuta el procedimiento almacenado, las instrucciones SQL se analizan, traducen y optimizan en tiempo de ejecución. Durante este proceso, cada instrucción se convierte en consultas distribuidas. El código SQL que se ejecuta en los datos es diferente de la consulta enviada.
Anidamiento de los procedimientos almacenados
Cuando los procedimientos almacenados llaman a otros procedimientos almacenados o ejecutan SQL dinámico, se dice que la invocación interna de código o de procedimientos almacenados se anida.
El grupo de SQL dedicado admite un máximo de ocho niveles de anidamiento. En cambio, el nivel de anidamiento en SQL Server es 32.
La llamada al procedimiento almacenado de nivel superior es igual al nivel de anidamiento 1.
EXEC prc_nesting
Si el procedimiento almacenado también realiza otra llamada EXEC, el nivel de anidamiento aumentará a 2.
CREATE PROCEDURE prc_nesting
AS
EXEC prc_nesting_2 -- This call is nest level 2
GO
EXEC prc_nesting
Si el segundo procedimiento ejecuta luego SQL dinámico, el nivel de anidamiento aumentará a 3.
CREATE PROCEDURE prc_nesting_2
AS
EXEC sp_executesql 'SELECT 'another nest level' -- This call is nest level 2
GO
EXEC prc_nesting
Actualmente, el grupo de SQL dedicado no admite @@NESTLEVEL. Por tanto, debe realizar un seguimiento del nivel de anidamiento. Es poco probable que supere el límite de ocho niveles de anidamiento. Sin embargo, si lo hace, debe reutilizar el código para ajustarse a los niveles de anidamiento dentro de este límite.
INSERT..EXECUTE
El grupo de SQL dedicado no permite utilizar el conjunto de resultados de un procedimiento almacenado con una instrucción INSERT. Sin embargo, puede utilizar un método alternativo. Para ver un ejemplo, consulte el artículo sobre tablas temporales.
Limitaciones
Existen algunos aspectos de los procedimientos almacenados de Transact-SQL que no se implementan en el grupo de SQL dedicado, como los siguientes:
- Procedimientos almacenados temporales
- Procedimientos almacenados numerados
- Procedimientos almacenados extendidos
- Procedimientos almacenados CLR
- Opción de cifrado
- Opción de replicación
- Parámetros con valores de tabla
- Parámetros de solo lectura
- Parámetros predeterminados
- Contextos de ejecución
- Instrucción de devolución
Pasos siguientes
Para obtener más sugerencias sobre desarrollo, vea la información general sobre desarrollo.