summaryrefslogtreecommitdiff
path: root/django/db/models/expressions.py
diff options
context:
space:
mode:
authortoan <toan.vuong@hyperscience.com>2023-09-21 15:51:45 -0700
committerMariusz Felisiak <felisiak.mariusz@gmail.com>2023-09-22 09:33:50 +0200
commit4de31ec680df062e5964b630f1b881ead5004e15 (patch)
treefedffba2e27c1585a647b1bd97f30a7538cd7cf0 /django/db/models/expressions.py
parentd7972436639bacada0f94d3b9818446343af59ad (diff)
Fixed #34858 -- Corrected resolving output_field for PositiveIntegerField.
Regression in 40b8a6174f001a310aa33f7880db0efeeb04d4c4.
Diffstat (limited to 'django/db/models/expressions.py')
-rw-r--r--django/db/models/expressions.py19
1 files changed, 19 insertions, 0 deletions
diff --git a/django/db/models/expressions.py b/django/db/models/expressions.py
index 4ea179ecde..30d44650ec 100644
--- a/django/db/models/expressions.py
+++ b/django/db/models/expressions.py
@@ -512,6 +512,25 @@ class Expression(BaseExpression, Combinable):
_connector_combinations = [
# Numeric operations - operands of same type.
+ # PositiveIntegerField should take precedence over IntegerField (except
+ # subtraction).
+ {
+ connector: [
+ (
+ fields.PositiveIntegerField,
+ fields.PositiveIntegerField,
+ fields.PositiveIntegerField,
+ ),
+ ]
+ for connector in (
+ Combinable.ADD,
+ Combinable.MUL,
+ Combinable.DIV,
+ Combinable.MOD,
+ Combinable.POW,
+ )
+ },
+ # Other numeric operands.
{
connector: [
(fields.IntegerField, fields.IntegerField, fields.IntegerField),