mirror of
https://github.com/django/django.git
synced 2025-12-03 08:32:59 +00:00
Fixed #26608 -- Added support for window expressions (OVER clause).
Thanks Josh Smeaton, Mariusz Felisiak, Sergey Fedoseev, Simon Charettes, Adam Chainz/Johnson and Tim Graham for comments and reviews and Jamie Cockburn for initial patch.
This commit is contained in:
parent
da1ba03f1d
commit
d549b88050
25 changed files with 1627 additions and 8 deletions
|
|
@ -13,7 +13,7 @@ from string import ascii_uppercase
|
|||
from django.core.exceptions import (
|
||||
EmptyResultSet, FieldDoesNotExist, FieldError,
|
||||
)
|
||||
from django.db import DEFAULT_DB_ALIAS, connections
|
||||
from django.db import DEFAULT_DB_ALIAS, NotSupportedError, connections
|
||||
from django.db.models.aggregates import Count
|
||||
from django.db.models.constants import LOOKUP_SEP
|
||||
from django.db.models.expressions import Col, Ref
|
||||
|
|
@ -1125,6 +1125,13 @@ class Query:
|
|||
if not arg:
|
||||
raise FieldError("Cannot parse keyword query %r" % arg)
|
||||
lookups, parts, reffed_expression = self.solve_lookup_type(arg)
|
||||
|
||||
if not getattr(reffed_expression, 'filterable', True):
|
||||
raise NotSupportedError(
|
||||
reffed_expression.__class__.__name__ + ' is disallowed in '
|
||||
'the filter clause.'
|
||||
)
|
||||
|
||||
if not allow_joins and len(parts) > 1:
|
||||
raise FieldError("Joined field references are not permitted in this query")
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue