This hands-on lab teaches you more advanced SQL including table relationship types, how to join multiple tables together, and how to write SQL queries that are faster and more scalable for your WordPress projects. You will use a practical example plugin to test two different approaches to solving the problem of fetching posts that are grouped by each term. You’ll test these approaches, explore the actual SQL queries, and learn about the impact of processing speed, performance, and scalability.
The best way to learn advanced concepts is to use examples you can relate to, i.e. that are in the context of WordPress. The problem you are solving is to get the posts grouped by each term while doing it as quickly as possible and ensure performance and scalability.
You’ll learn about table relationships and how to join them together to drill down to the information you need for your query. You’ll learn about the complex relationship between posts, terms, and taxonomies as well as their associated metadata. You’ll learn about how WordPress communicates with the database via
This lab presents two different approaches to solving the same problem. These approaches are very different and each has an impact on processing speed, performance, and scalability.
- Approach 1: Use
get_termsto get all the terms first. Then you’ll loop through each term and go fetch the posts for it.
- Approach 2: Use one SQL query to fetch all of the information. That’s one database hit.
For each approach, you’ll learn about how many times the database is hit as well as take a deep dive into the actual SQL queries each generates.
What You Will Learn
Here is a summary of what you will learn:
- Relational types in MySQL, one-to-many, many-to-many, etc.
- How to join multiple database tables together to fetch the information you need from the database.
- Learn about different
- Relationship between posts, terms, and taxonomy, including how to fetch what you need.
- Grouping results using the SQL command
- Ordering results using the SQL command
- Introduction to the WordPress global
- Preparing results using
- Running the query using
- Performance and scalability
In order to do this lab, you will need the following:
- Introduction to Database hands-on lab
- Groupby Lab Tester companion plugin
- A local web server, such as Local by Flywheel, VVV, MAMP, WAMP, Desktop Server, or some other application.
- A database interface such as Sequel Pro (which is what Tonya uses) or phpMyAdmin.
- Your favorite IDE or editor. (Tonya uses PhpStorm.)
- A local sandbox website
Hands off the keyboard. Web development starts by thinking first, then planning it out, and then coding it.
Total Lab Runtime: 02:46:48
- 1 Lab Introductionfree 14:27
- 2 Slow Approach Overviewpro 12:11
- 3 Test Slow Approach - Part 1pro 17:27
- 4 Test Slow Approach - Part 2pro 21:07
- 5 Relational Typespro 23:20
- 6 Types of Joinspro 09:30
- 7 Joining Metadatapro 12:37
- 8 Joining Posts to Termspro 20:32
- 9 Grouping Datasetspro 08:32
- 10 WordPress SQL Handler $wpdbpro 11:01
- 11 Deeper Dive into $wpdb->get_resultspro 05:54
- 12 Run Fast Approach & Compare Resultspro 10:10
Do you want to build plugins professionally? Then this is the series for you. You and Tonya will dive deep into the entire process of building a real world, fully-functional, custom plugin from scratch. You will learn deeply about architecture, planning, WordPress, PHP, jQuery, SQL, HTML, and so much more. This plugin includes a custom post type, custom taxonomy, shortcodes, and more. You'll build it, add to it, make it better, and then convert to OOP.
Check out the SQL Library for more hands-on labs, insights, Docx, and more.
To learn more about the specific SQL commands you will be using, there are various courses and resources available to you. Some include: