Fixed #36233 -- Avoided quantizing integers stored in DecimalField on SQLite.

Co-authored-by: Simon Charette <charette.s@gmail.com>
Co-authored-by: Jacob Walls <jacobtylerwalls@gmail.com>
This commit is contained in:
Samriddha9619
2026-01-20 01:38:34 +05:30
committed by Jacob Walls
parent e61a54d306
commit 2831eaed79
3 changed files with 27 additions and 3 deletions

View File

@@ -102,6 +102,7 @@ class Choiceful(models.Model):
class BigD(models.Model):
d = models.DecimalField(max_digits=32, decimal_places=30)
large_int = models.DecimalField(max_digits=16, decimal_places=0, null=True)
class FloatModel(models.Model):

View File

@@ -5,6 +5,7 @@ from unittest import mock
from django.core import validators
from django.core.exceptions import ValidationError
from django.db import connection, models
from django.db.models import Max
from django.test import TestCase
from .models import BigD, Foo
@@ -140,3 +141,20 @@ class DecimalFieldTests(TestCase):
obj = Foo.objects.create(a="bar", d=Decimal("8.320"))
obj.refresh_from_db()
self.assertEqual(obj.d.compare_total(Decimal("8.320")), Decimal("0"))
def test_large_integer_precision(self):
large_int_val = Decimal("9999999999999999")
obj = BigD.objects.create(large_int=large_int_val, d=Decimal("0"))
obj.refresh_from_db()
self.assertEqual(obj.large_int, large_int_val)
def test_large_integer_precision_aggregation(self):
large_int_val = Decimal("9999999999999999")
BigD.objects.create(large_int=large_int_val, d=Decimal("0"))
result = BigD.objects.aggregate(max_val=Max("large_int"))
self.assertEqual(result["max_val"], large_int_val)
def test_roundtrip_integer_with_trailing_zeros(self):
obj = Foo.objects.create(a="bar", d=Decimal("8"))
obj.refresh_from_db()
self.assertEqual(obj.d.compare_total(Decimal("8.000")), Decimal("0"))