Return raw data
Following methods allow you to execute a query but instead of returning ormar models those will return list of dicts or tuples.
values(fields = None, exclude_through = False) -> List[Dict]
-
values_list(fields = None, exclude_through = False, flatten = False) -> List
-
QuerysetProxy
QuerysetProxy.values(fields = None, exclude_through = False)
methodQuerysetProxy.values_list(fields = None, exclude_through= False, flatten = False)
method
Danger
Note that values
and values_list
skips parsing the result to ormar models so skips also the validation of the result!
Warning
Note that each entry in a result list is one to one reflection of a query result row. Since rows are not parsed if you have one-to-many or many-to-many relation expect duplicated columns values in result entries if one parent row have multiple related rows.
values
values(fields: Union[List, str, Set, Dict] = None, exclude_through: bool = False) -> List[Dict]
Return a list of dictionaries representing the values of the columns coming from the database.
You can select a subset of fields with fields parameter, that accepts the same set of parameters as fields()
method.
Note that passing fields to values(fields)
is actually a shortcut for calling fields(fields).values()
.
Tip
To read more about what you can pass to fields and how to select nested models fields read selecting columns docs
You can limit the number of rows by providing conditions in filter()
and exclude()
, but note that even if only one row (or no rows!) match your criteria you will return a list in response.
Example:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
Access Post models:
1 2 3 4 5 6 |
|
To select also related models use select_related
or prefetch_related
.
Note how nested models columns will be prefixed with full relation path coming from the main model (the one used in a query).
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
Select user with roles
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
|
Note
Note how role to users relation is a ManyToMany
relation so by default you also get through model columns.
Combine select related and fields to select only 3 fields.
Note that we also exclude through model as by definition every model included in a join but without any reference in fields is assumed to be selected in full (all fields included).
Note
Note that in contrary to other queryset methods here you can exclude the in-between models but keep the end columns, which does not make sense when parsing the raw data into models.
So in relation category -> category_x_post -> post -> user you can exclude category_x_post and post models but can keep the user one. (in ormar model context that is not possible as if you would exclude through and post model there would be no way to reach user model from category model).
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
If you have multiple ManyToMany models in your query you would have to exclude each through model manually.
To avoid this burden ormar
provides you with exclude_through=False
parameter.
If you set this flag to True all through models will be fully excluded.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
values_list
values_list(fields: Union[List, str, Set, Dict] = None, flatten: bool = False, exclude_through: bool = False) -> List
Return a list of tuples representing the values of the columns coming from the database.
You can select a subset of fields with fields parameter, that accepts the same set of parameters as fields()
method.
Note that passing fields to values_list(fields)
is actually a shortcut for calling fields(fields).values_list()
.
Tip
To read more about what you can pass to fields and how to select nested models fields read selecting columns docs
If you select only one column/field you can pass flatten=True
which will return you a list of values instead of list of one element tuples.
Warning
Setting flatten=True
if more than one (or none which means all) fields are selected will raise QueryDefinitionError
exception.
You can limit the number of rows by providing conditions in filter()
and exclude()
, but note that even if only one row (or no rows!) match your criteria you will return a list in response.
Example:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
Access Post models:
1 2 3 4 5 6 7 |
|
To select also related models use select_related
or prefetch_related
.
Let's complicate the relation and modify the previously mentioned Category model to refer to User model.
1 2 3 4 5 6 7 8 9 |
|
Now create the sample data with link to user.
1 2 3 4 5 6 |
|
Combine select related and fields to select only 3 fields.
Note that we also exclude through model as by definition every model included in a join but without any reference in fields is assumed to be selected in full (all fields included).
Note
Note that in contrary to other queryset methods here you can exclude the in-between models but keep the end columns, which does not make sense when parsing the raw data into models.
So in relation category -> category_x_post -> post -> user you can exclude category_x_post and post models but can keep the user one. (in ormar model context that is not possible as if you would exclude through and post model there would be no way to reach user model from category model).
1 2 3 4 5 6 7 8 |
|
If you have multiple ManyToMany models in your query you would have to exclude each through model manually.
To avoid this burden ormar
provides you with exclude_through=False
parameter.
If you set this flag to True all through models will be fully excluded.
1 2 3 4 5 6 7 8 |
|
Use flatten to get list of values.
1 2 3 4 5 6 |
|
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.
Warning
Because using values
and values_list
skips parsing of the models and validation, in contrast to all other read methods in querysetproxy those 2 does not clear currently loaded related models and does not overwrite the currently loaded models with result of own call!
values
Works exactly the same as values function above but allows you to fetch related objects from other side of the relation.
Tip
To read more about QuerysetProxy
visit querysetproxy section
values_list
Works exactly the same as values_list 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