Sharingan,
Les étapes dans la procédure stockée n'entraînent pas le délai. Le client appelant le SP a une valeur de délai d'attente, et si le SP prend plus de temps, il "pense" que quelque chose ne va pas. Cela ne signifie pas que votre SP est mal conçu ou qu'il a réellement échoué. Une approche consiste à créer une table de journalisation, et dans votre procédure stockée, au début, supprimer toutes les lignes de cette table (c'est une table TEMP qui est effacée chaque fois que le SP s'exécute). Ensuite, avant chaque étape de la procédure, insérez une ligne dans votre table de journalisation avec quelque chose comme «Démarrer l'ETL de l'employé ...» et après l'étape «Terminé Employee ETL ...».
Vous pouvez également vérifier si une erreur s'est produite après chaque étape et écrire le message d'erreur dans cette table. Cela devient effectivement votre propre journal.
IF @@ERROR <> 0
BEGIN
-- Add Error_Message to your table
END
Si le processus d'appel n'a pas la valeur de délai d'attente correctement configuré, vous pouvez voir que la SP se termine en fait (en examinant votre journal), mais le client pense à tort quelque chose est erroné parce que la valeur du délai d'attente a été dépassé . Une erreur de délai d'attente au niveau du client n'arrêtera pas SQL Server d'avancer avec le travail.
Pouvez-vous essayer d'exécuter la procédure stockée par elle-même, à partir de SSMS, par exemple? Si cela fonctionne, vous êtes sur la bonne voie pour repérer le problème, mais il est important de distinguer s'il s'agit de SQL ou de votre client, comme une application Azure Logic, ou de tout autre processus lancant le processus ETL. Vous devrez peut-être fabriquer/simuler tous les paramètres passés dans le SP, mais cela devrait être facile dans SSMS.
Vous pouvez également diviser un gros SP en un groupe de plus petits, et ajouter d'autres étapes à votre client ETL, au lieu d'un énorme appel SP. Cela peut vous obliger à implémenter une gestion des erreurs transitoires, mais cela peut être gérable dans votre situation.
Bonne chance!