Skip to content
Learn Netverks

Lesson

Step 21/36 58% through track

queryset-basics

QuerySet basics

Last reviewed May 28, 2026 Content v20260528
Track mode
server_script
Means
Server runner
Reading
~2 min
Level
intermediate

This lesson

This lesson teaches QuerySet basics: the syntax, APIs, and habits you need before advancing in Django.

Teams ship QuerySet basics on every Django codebase—skipping it leaves gaps in debugging and code reviews.

You will apply QuerySet basics in contexts like: Blog engines, e-commerce catalogs, and multi-tenant SaaS data layers.

Write Python 3 in the editor and click Run on server—the dev runner executes your script; Django framework lessons also use local startproject for full MVT (LEARNING_RUNNER_ENABLED=true).

When you can explain the previous lesson's ideas without copying starter code.

A QuerySet represents a database query you can chain, slice, and iterate. Querysets are lazy—they hit the database only when evaluated.

Common operations

Article.objects.all()
Article.objects.filter(published=True)
Article.objects.exclude(title="Draft")
Article.objects.get(pk=5)  # one row or exception
Article.objects.order_by("-created_at")[:10]

Field lookups

title__icontains="django", created_at__year=2024, author__name="Ada"—double underscore spans relationships.

Performance tip

Use select_related for ForeignKey (SQL JOIN) and prefetch_related for ManyToMany/reverse FK to avoid N+1 queries.

Important interview questions and answers

  1. Q: filter vs get?
    A: filter returns QuerySet (0+ rows); get returns one row or raises DoesNotExist/MultipleObjectsReturned.
  2. Q: What is N+1?
    A: One query for a list plus one per row for related data—fix with select_related/prefetch_related.
  3. Q: QuerySet caching?
    A: Evaluated querysets cache results; chaining after evaluation may re-query—know when evaluation happens.

Self-check

  1. When does a queryset execute SQL?
  2. How do you fetch related author in one query?

Pitfall: Calling len() or bool() on a huge queryset still hits the database—use .exists() or .count() intentionally, and prefer slicing for previews.

Interview prep

What is N+1?

One query for a list plus one per row for related objects—fix with select_related (FK) or prefetch_related (M2M/reverse FK).

Interview tip Lesson completion confidence

Can you explain this lesson in 30 seconds without reading notes?

Not saved yet.

Playground

Runs on the configured server runner (dev: npm run runner with LEARNING_RUNNER_ENABLED=true). Output appears below the editor.

Check yourself

Multiple choice — immediate feedback.

Discussion

Past discussion is visible to everyone. Only logged-in users can post comments and replies.

Starter discussion topics

  • filter vs get?
  • N+1 query fix?

Sign up or log in to post comments and sync lesson progress across devices.

No discussion yet. Be the first to ask a question.

Jump