Read our blogs, tips and tutorials
Try our exercises or test your skills
Watch our tutorial videos or shorts
Take a self-paced course
Read our recent newsletters
License our courseware
Book expert consultancy
Buy our publications
Get help in using our site
551 attributed reviews in the last 3 years
Refreshingly small course sizes
Outstandingly good courseware
Whizzy online classrooms
Wise Owl trainers only (no freelancers)
Almost no cancellations
We have genuine integrity
We invoice after training
Review 30+ years of Wise Owl
View our top 100 clients
Search our website
We also send out useful tips in a monthly email newsletter ...
Software ==> | SQL (203 exercises) |
Topic ==> | Parameters and return values (17 exercises) |
Level ==> | Average difficulty |
Subject ==> | SQL training |
This exercise is provided to allow potential course delegates to choose the correct Wise Owl Microsoft training course, and may not be reproduced in whole or in part in any format without the prior written consent of Wise Owl.
If you don't have a copy of the Music_01 database, follow the instructions at the following link to create it: www.wiseowl.co.uk/sql/exercises/standard/using-sql-server/5257/
Open the file called The Show Must Go On.sql. You'll find a script to create a stored procedure which returns a list of shows, including information on whether a show was cancelled.
The Cancelled column contains 1 if a show was cancelled, and 0 if it was not.
Add a parameter called @CancelledOrNot to the procedure using the BIT data type. Add a WHERE clause to the query to check if the value of the Cancelled column equals the value of the parameter.
Create a new script to test that the procedure works.
The show must go on... except when it doesn't.
It's annoying to have to provide a value to the parameter each time we execute the script. Assign a default value of 0 to the parameter so that the procedure returns the non-cancelled shows if you don't pass any value to the parameter.
Test that the procedure returns results when you don't pass a value to the parameter.
Ideally, if we don't pass a value to the parameter, we should see both the cancelled and non-cancelled shows. Assign a default value of NULL to the parameter. Modify the WHERE clause so that a row is returned if either:
The Cancelled column is equal to the value of the @CancelledOrNot parameter; or
The @CancelledOrNot parameter is null.
Test that the procedure returns the correct type of show whether or not you pass a value to the parameter.
Add two optional date parameters called @StartDate and @EndDate which allow you to search for shows which happened between any two dates.
Test that you can pass any combination of values to the stored procedure.
We're searching for shows cancelled in the start of 2020. I wonder what the main cause of cancellation will be...
Optionally, save both scripts and then close them.
You can find other training resources for the subject of this exercise here:
Kingsmoor House
Railway Street
GLOSSOP
SK13 2AA
Landmark Offices
99 Bishopsgate
LONDON
EC2M 3XD
Holiday Inn
25 Aytoun Street
MANCHESTER
M1 3AE
© Wise Owl Business Solutions Ltd 2025. All Rights Reserved.