Σήμερα έφτιαξα μια αρκετά περίπλοκη 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