Read data from database
Following methods allow you to load data from the database.
get(*args, **kwargs) -> Model
get_or_create(_defaults: Optional[Dict[str, Any]] = None, *args, **kwargs) -> Tuple[Model, bool]
first(*args, **kwargs) -> Model
all(*args, **kwargs) -> List[Optional[Model]]
-
iterate(*args, **kwargs) -> AsyncGenerator[Model]
-
Model
Model.load()
method
-
QuerysetProxy
QuerysetProxy.get(*args, **kwargs)
methodQuerysetProxy.get_or_create(_defaults: Optional[Dict[str, Any]] = None, *args, **kwargs)
methodQuerysetProxy.first(*args, **kwargs)
methodQuerysetProxy.all(*args, **kwargs)
method
get
get(*args, **kwargs) -> Model
Gets the first row from the db meeting the criteria set by kwargs.
If no criteria set it will return the last row in db sorted by pk column.
Passing a criteria is actually calling filter(args, *kwargs) method described below.
1 2 3 4 5 6 7 8 9 10 |
|
1 2 3 4 5 6 |
|
Warning
If no row meets the criteria NoMatch
exception is raised.
If there are multiple rows meeting the criteria the MultipleMatches
exception is raised.
get_or_none
get_or_none(*args, **kwargs) -> Model
Exact equivalent of get described above but instead of raising the exception returns None
if no db record matching the criteria is found.
get_or_create
get_or_create(_defaults: Optional[Dict[str, Any]] = None, *args, **kwargs) -> Tuple[Model, bool]
Combination of create and get methods.
Tries to get a row meeting the criteria and if NoMatch
exception is raised it creates
a new one with given kwargs and _defaults.
1 2 3 4 5 6 7 8 9 |
|
1 2 3 4 5 6 7 8 9 |
|
Warning
Despite being an equivalent row from database the album
and album2
in
example above are 2 different python objects!
Updating one of them will not refresh the second one until you explicitly load() the
fresh data from db.
Note
Note that if you want to create a new object you either have to pass pk column value or pk column has to be set as autoincrement
first
first(*args, **kwargs) -> Model
Gets the first row from the db ordered by primary key column ascending.
1 2 3 4 5 6 7 8 |
|
1 2 3 4 5 |
|
all
all(*args, **kwargs) -> List[Optional["Model"]]
Returns all rows from a database for given model for set filter options.
Passing kwargs is a shortcut and equals to calling filter(*args, **kwargs).all()
.
If there are no rows meeting the criteria an empty list is returned.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
1 2 3 4 5 6 |
|
iterate
iterate(*args, **kwargs) -> AsyncGenerator["Model"]
Return async iterable generator for all rows from a database for given model.
Passing args and/or kwargs is a shortcut and equals to calling filter(*args, **kwargs).iterate()
.
If there are no rows meeting the criteria an empty async generator is returned.
1 2 3 4 5 6 7 8 |
|
1 2 3 4 5 6 7 8 |
|
Warning
Use of iterate()
causes previous prefetch_related()
calls to be ignored;
since these two optimizations do not make sense together.
If iterate()
& prefetch_related()
are used together the QueryDefinitionError
exception is raised.
Model methods
Each model instance have a set of methods to save
, update
or load
itself.
load
You can load the ForeignKey
related model by calling load()
method.
load()
can be used to refresh the model from the database (if it was changed by some other process).
Tip
Read more about load()
method in models methods
QuerysetProxy methods
When access directly the related ManyToMany
field as well as ReverseForeignKey
returns the list of related models.
But at the same time it exposes subset of QuerySet API, so you can filter, create, select related etc related models directly from parent model.
get
Works exactly the same as get function above but allows you to fetch related objects from other side of the relation.
Tip
To read more about QuerysetProxy
visit querysetproxy section
get_or_none
Exact equivalent of get described above but instead of raising the exception returns None
if no db record matching the criteria is found.
Tip
To read more about QuerysetProxy
visit querysetproxy section
get_or_create
Works exactly the same as get_or_create function above but allows you to query or create related objects from other side of the relation.
Tip
To read more about QuerysetProxy
visit querysetproxy section
first
Works exactly the same as first function above but allows you to query related objects from other side of the relation.
Tip
To read more about QuerysetProxy
visit querysetproxy section
all
Works exactly the same as all function above but allows you to query related objects from other side of the relation.
Tip
To read more about QuerysetProxy
visit querysetproxy section