go backsqlschool blogs list

Show execution progress to SSMS message tab during stored procedure execution

by Antonios Chatzipavlis

Σήμερα έφτιαξα μια αρκετά περίπλοκη stored procedure η οποία έκανε μια μεγάλη σε διάρκεια διαδικασία και αυτή την επικοινώνησα με συναδέλφους για να τους εξηγήσω τι ακριβώς κάνει.

Ένας συνάδελφος εντυπωσιάστηκε με το γεγονός ότι στο SSMS Message tab εμφανίζονταν διάφορα μηνύματα με τα οποία μπορούσε να ελέγξει το execution progress και φυσικά ρώτησε πως αυτό το έχω φτιάξει.

Η απάντηση είναι εξής

Τα PRINT commands δεν είναι χρήσιμα καθώς θα εμφανιστούν όλα στο τέλος της εκτέλεσης της stored procedure.

Αυτό που μπορεί κανείς να κάνει είναι να χρησιμοποιήσει την RAISERROR αλλά θα πρέπει να έχει πρώτα καταλάβει το SEVERITY LEVEL και να βάλει κάτι που να είναι information δηλαδή μεταξύ 0-10 στη παράμετρο severity της RAISERROR.

Οτιδήποτε είναι σε αυτό το range δεν θεωρείται λάθος οπότε η εκτέλεση συνεχίζει κανονικά. Τέλος με το WITH NOWAIT λέμε αυτό να εμφανιστεί αμέσως στο message tab.

Μια ακόμα παρατήρηση είναι ότι εφόσον θέλω να «κτίσω» το message αυτό θα πρέπει να το κάνω σε ξεχωριστή μεταβλητή και αυτή να βάλω στην αντίστοιχη παράμετρο της RAISERROR καθώς αυτή δεν επιτρέπει κανενός είδους string concatenation.

set @msg = 'Counting Rows...';
raiserror ( @msg, 0, 1) with nowait;


//antonch


Ημερομηνία: 09 August 2017 18:09
Αξιολόγηση: ( 1 )
Κατηγορίες:
Share it:

Σχετικά Blog Post

Αφήστε το σχόλιο σας - Leave your comment

Τα σχόλια έχουν κλείσει.
Επιτρέπονται μόνο τα σχόλια από τα μέλη του SqlSchool.gr.


newsletter subscription

Εάν επιθυμείτε να λαμβάνετε ενημέρωση από εμάς, δώστε μας το e-mail σας.
PASS chapter logo
Official Professional Association for SQL Server (PASS) chapter for Greece
Join to PASS