SQL and ActiveRecord Workshop
Learning Goals
- Get more practice using the more advanced SQL techniques like joins, grouping, and aggregating
- Use ActiveRecord, SQL, or both to implement queries
Set Up
We’ll be using the sql_ar_workshop_m4
branch of the Set List API. The instructions for this class are also listed on this branch in the README.
Warm Up
Write a method that will return all Artists with Songs with at least 1,000,000 plays.
Use TDD to write this method. First decide which model you’d like to define the method in and whether it is a class or instance method.
Then start writing your test. Call the method defined in spec/helper_methods.rb
to populate your test with data.
Once you have your test, start writing the method.
Framework for Approaching Complex Query Problems
- What tables do we need?
- If I need more than one, I need to use a
join
- If I need more than one, I need to use a
- What columns do I need (think:
select
)? - What rows do I need?
- Filtering often uses a
where
clause, or when dealing with filtering using an aggregate function, ahaving
clause
- Filtering often uses a
- Do I need to make a calculation? (think: aggregate functions)
- Before making that calculation, do I need to consolidate the data into any groups with a
group by
statement? - Using
group by
is not always necessary when doing a simple calculation like “what is the total number of plays of all songs in our database?”
- Before making that calculation, do I need to consolidate the data into any groups with a
- Do we need to format the output? (think:
order
,distinct
,limit
)
Practice Problems
Each of these problems has tests created for you. You will need to define the method. Each test is skipped, so unskip each test as you work through the problems.
Set 1 - As a Class
We will work on these problems in Breakout Rooms. Then we will come together and discuss as a class.
spec/models/song_spec.rb:19
- Get a unique list of all Songs on all playlists.spec/models/artist_spec.rb:38
- Get a unique list of all the Artists on all Playlists created after Jan 1, 2020.spec/models/artist_spec.rb:23
- Get a list of all Playlist that have songs from a specific Artist ordered alphabetically by the Playlist name
Set 2 - Choose your own Adventure
Pick one of the following problems to work on. You will split in to groups to work on your chosen problem. Then we will review each problem as a class. They are listed from least to most difficult.
spec/models/artist_spec.rb:44
- Get the 3 Artists with the highest total play_counts of all of their songs. This problem will require you to use joining, grouping, and aggregating.spec/models/playlist_spec.rb:8
- Get the Playlist with the longest total length. This problem will also require you to use joining, grouping, and aggregating. It may be slightly more challenging than the previous problem since it starts from the Playlist model which we haven’t seen yet.spec/models/artist_spec.rb:54
- Get all Artists with Songs on 3 different Playlists. This problem is a step up in difficulty and may require you to use concepts that we haven’t discussed in class.
Solutions
Each of these problems could have multiple answers. Possible solutions can be found on the sql_ar_workshop_solutions
branch of Set List here. We encourage you to look at solutions in your browser and then try to implement them locally in your VSCode.