#30631 closed New feature (wontfix)
Prefixing Q Objects.
| Reported by: | Robert Schindler | Owned by: | nobody |
|---|---|---|---|
| Component: | Database layer (models, ORM) | Version: | dev |
| Severity: | Normal | Keywords: | prefix q objects |
| Cc: | Triage Stage: | Unreviewed | |
| Has patch: | yes | Needs documentation: | yes |
| Needs tests: | yes | Patch needs improvement: | no |
| Easy pickings: | no | UI/UX: | no |
Description (last modified by )
I'm currently spending a lot of time on development of a project using Django and worked out something that I think could be of use for all Django users.
I added a new .prefix(prefix) method to the Q object, allowing to shift pre-built q objects to a related field. I think this can change the way people build managers completely, because instead of methods returning filtered querysets, one can just return Q objects, which can then be used from related models without repeating the filtering logic.
This is the simple implementation.
class Q(django.db.models.Q):
"""
A custom Q implementation that allows prefixing existing Q objects with some
related field name dynamically.
"""
def prefix(self, prefix):
"""Recursively copies the Q object, prefixing all lookup keys.
The prefix and the existing filter key are delimited by the lookup separator __.
Use this feature to delegate existing query constraints to a related field.
"""
return type(self)(
*(
child.prefix(prefix)
if isinstance(child, Q)
else (prefix + LOOKUP_SEP + child[0], child[1])
for child in self.children
),
_connector=self.connector,
_negated=self.negated,
)
What do you think, is it worth creating a PR for this functionality? I haven't written the docs yet, but could write something if you like the addition.
Best regards
Robert
Change History (4)
comment:1 by , 6 years ago
| Description: | modified (diff) |
|---|---|
| Needs documentation: | set |
| Needs tests: | set |
comment:2 by , 6 years ago
| Resolution: | → wontfix |
|---|---|
| Status: | new → closed |
| Summary: | Prefixing Q Objects → Prefixing Q Objects. |
| Version: | 2.2 → master |
comment:3 by , 6 years ago
Ok, I posted to the mailing list, but I think you've misunderstood the use case I proposed. Let's see how it goes.
comment:4 by , 6 years ago
Discussion continued at mailing list: https://groups.google.com/d/msg/django-developers/jEkCdzGnzRE/kXgYt7r0CgAJ
Thanks for this proposition. It is interesting idea but I don't see many use cases and to be honest it would be confusing to me to use, e.g.:
Q(Q(field__startswith='x') | Q(other_field__startswith='y')).prefix('related_field') & Q(base_field__gte=78)instead of
Please write to the DevelopersMailingList if you want other opinions, we can re-open this ticket if we reach a consensus on the mailing list.