When I do this,
>>> b = Blog.objects.all()
>>> b
I get this:
>>>[,
A django queryset is like its name says, basically a collection of (sql) queries, in your example above print(b.query)
will show you the sql query generated from your django filter
calls.
Since querysets are lazy, the database query isn't done immediately, but only when needed - when the queryset is evaluated. This happens for example if you call its __str__
method when you print it, if you would call list()
on it, or, what happens mostly, you iterate over it (for post in b..
). This lazyness should save you from doing unnecessary queries and also allows you to chain querysets and filters for example (you can filter a queryset as often as you want to).
A QuerySet is a list of objects of a given model, QuerySet allow you to read data from database
A QuerySet represents a collection of objects from your database. It can have zero, one or many filters. Filters narrow down the query results based on the given parameters. In SQL terms, a QuerySet equates to a SELECT statement, and a filter is a limiting clause such as WHERE or LIMIT.
https://docs.djangoproject.com/en/1.8/topics/db/queries/
Yes, it's just another type, built like every other type.