1. Course overview and setup
10m

👋 Welcome to data loaders with Apollo Server & TypeScript!

We're excited you're here! Together we'll set our sights on improving performance in our applications, zooming in on the best practice of using data loaders. We've got lots of hands-on opportunities ahead, and you'll find quizzes and challenges to test your understanding as we tackle this topic.

In this course, we'll address one of the sneaky performance problems that can appear in projects: the n+1 problem. Once we understand how this problem occurs, we'll implement the solution using data loaders. We'll walk through the steps of implementing and using data loaders in our TypeScript project, and see the direct effect they have on our app's performance.

Let's jump in!

What we're building

To explore this topic, we'll build on top of an existing app called: Airlock.

Mockup of Airlock

Airlock is an intergalactic trip booking app: a resource we can use to find a cool place to stay in the wide open universe! We built the basics of this in the Intro to GraphQL course.

But don't worry—you don't need to have completed the first course before starting! We'll give you a fresh repo to clone, and walk you through all the steps to get data loaders up and running.

Let's get everything ready to start building!

Project setup

To follow along with the course, you will need the following:

Prerequisite knowledge

We assume that you are familiar with concepts like types, queries, and . Check out our Intro to GraphQL with Apollo Server & TypeScript course if you need a refresher.

You should also be familiar with TypeScript programming concepts.

Code editor or IDE

We're using VS Code.

Many popular IDEs offer plugins that enable syntax highlighting. For VS Code, we recommend the GraphQL: Syntax Highlighting extension.

Clone the repository

This course picks up where Intro to GraphQL with Apollo Server & TypeScript left off, but completing it first isn't a prerequisite! To start fresh, run the following command.

git clone https://github.com/apollographql-education/odyssey-dataloaders-typescript.git

Running the app

Finally, let's get our server up and running.

Navigate to the root directory in your terminal, and run the following commands.

First, to install packages:

odyssey-dataloaders-typescript
npm install

Next, to boot up the server:

odyssey-dataloaders-typescript
npm run dev

Shortly after, we should see in the terminal that our app is running!

🚀 Server is running
📭 Query at http://localhost:4000/
Task!

Up next

Let's get into data loaders, the problem they solve, and how we bring them into our application.

Next

Share your questions and comments about this lesson

Your feedback helps us improve! If you're stuck or confused, let us know and we'll help you out. All comments are public and must follow the Apollo Code of Conduct. Note that comments that have been resolved or addressed may be removed.

You'll need a GitHub account to post below. Don't have one? Post in our Odyssey forum instead.