WISE OWL EXERCISES
- Simple Queries (4)
- Setting criteria using WHERE (5)
- Calculations (7)
- Calculations using dates (4)
- Basic joins (8)
- More exotic joins (2)
- Aggregation and grouping (8)
- Views (5)
- Subqueries (5)
- Stored procedures (5)
- Variables (8)
- Parameters and return values (11)
- Testing conditions (1)
- Looping (3)
- Scalar functions (6)
- Transactions (5)
- Creating tables (5)
- Temporary tables and table variables (9)
- Table-valued functions (6)
- Derived tables and CTEs (13)
- Dynamic SQL (4)
- Pivots (2)
- Triggers (2)
- Archived (70)
SQL | Temporary tables and table variables exercise | Looping to add rows into temporary table
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.
The answer to the exercise will be included and explained if you attend one of more of the courses listed below!
- Go into SQL Server Management Studio;
- Open the SQL file you've just unzipped (you can press CTRL + O to do this); then
- Execute this script.
This will generate the database that you'll need to use in order to do this exercise (note that the database and script are only to be used for exercises published on this website, and may not be reused or distributed in any form without the prior written permission of Wise Owl).
You need a minimum screen resolution of about 700 pixels width to see our exercises. This is because they contain diagrams and tables which would not be viewable easily on a mobile phone or small laptop. Please use a larger tablet, notebook or desktop computer, or change your screen resolution settings.
The aim of this exercise is to create a temporary table showing the most eventful country for each year. One way to do this is to create a temporary table, and populate its rows within a loop.
The first 4 rows out of the 95 years that your query should return.
Note that this is not the only - or even the best - way to do this, but it does provide a useful exercise on temporary tables!
For details of how to proceed, please turn the page!
First write a query to create a temporary table with 3 columns:
|Year of events||Each year in the database|
|Country of events||The country for that year having most events|
|Number of events||The number of events for this country in this year|
Declare variables to hold the earliest and latest event years, and set their values:
Set the value of your two variables to hold the earliest and latest year referenced in the tblEvent table.
Use these variables to start a WHILE loop, which begins at the first year and stops at the last year, adding 1 each time round the loop.
Within your loop, insert one record into your temporary table containing:
- The current year number (the value of your counter variable within the loop);
- The country having the most events for this year; and
- The number of events for this country.
You can get this information by showing the number of events for each country, then adding the TOP 1 clause to pick out just the first country, as ordered by the number of events.
When everything is working, optionally save this exercise as Counting the years away.sql, then close it down.