From 8c257cecffc314179a5375ab8a16ca0ff3b6fb16 Mon Sep 17 00:00:00 2001 From: Mariusz Felisiak Date: Sat, 27 Apr 2024 03:36:07 +0200 Subject: [PATCH] Refs #35339 -- Fixed source expressions in GeoAggregate on Oracle. Regression in 42b567ab4c5bfb1bbd3e629b1079271c5ae44ea0. --- django/contrib/gis/db/models/aggregates.py | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/django/contrib/gis/db/models/aggregates.py b/django/contrib/gis/db/models/aggregates.py index 7ba2e756e7..abff1a5206 100644 --- a/django/contrib/gis/db/models/aggregates.py +++ b/django/contrib/gis/db/models/aggregates.py @@ -34,17 +34,14 @@ def as_oracle(self, compiler, connection, **extra_context): tolerance = self.extra.get("tolerance") or getattr(self, "tolerance", 0.05) clone = self.copy() source_expressions = self.get_source_expressions() - if self.filter: - source_expressions.pop() + source_expressions.pop() # Don't wrap filters with SDOAGGRTYPE(). spatial_type_expr = Func( *source_expressions, Value(tolerance), function="SDOAGGRTYPE", output_field=self.output_field, ) - source_expressions = [spatial_type_expr] - if self.filter: - source_expressions.append(self.filter) + source_expressions = [spatial_type_expr, self.filter] clone.set_source_expressions(source_expressions) return clone.as_sql(compiler, connection, **extra_context) return self.as_sql(compiler, connection, **extra_context)