mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #32203 -- Fixed QuerySet.values()/values_list() crash on key transforms with non-string values on SQLite.
Thanks Gordon Wrigley for the report.
This commit is contained in:
		| @@ -75,6 +75,10 @@ class JSONField(CheckFieldDefaultMixin, Field): | ||||
|     def from_db_value(self, value, expression, connection): | ||||
|         if value is None: | ||||
|             return value | ||||
|         # Some backends (SQLite at least) extract non-string values in their | ||||
|         # SQL datatypes. | ||||
|         if isinstance(expression, KeyTransform) and not isinstance(value, str): | ||||
|             return value | ||||
|         try: | ||||
|             return json.loads(value, cls=self.decoder) | ||||
|         except json.JSONDecodeError: | ||||
|   | ||||
| @@ -28,3 +28,7 @@ Bugfixes | ||||
| * Fixed a regression in Django 3.1 that caused suppressing connection errors | ||||
|   when :class:`~django.db.models.JSONField` is used on SQLite | ||||
|   (:ticket:`32224`). | ||||
|  | ||||
| * Fixed a crash on SQLite, when ``QuerySet.values()/values_list()`` contained | ||||
|   key transforms for :class:`~django.db.models.JSONField` returning non-string | ||||
|   primitive values (:ticket:`32203`). | ||||
|   | ||||
| @@ -277,6 +277,7 @@ class TestQuerying(TestCase): | ||||
|                 'k': {'l': 'm'}, | ||||
|                 'n': [None], | ||||
|                 'o': '"quoted"', | ||||
|                 'p': 4.2, | ||||
|             }, | ||||
|             [1, [2]], | ||||
|             {'k': True, 'l': False, 'foo': 'bax'}, | ||||
| @@ -753,10 +754,14 @@ class TestQuerying(TestCase): | ||||
|         qs = NullableJSONModel.objects.filter(value__h=True) | ||||
|         tests = [ | ||||
|             ('value__a', 'b'), | ||||
|             ('value__c', 14), | ||||
|             ('value__d', ['e', {'f': 'g'}]), | ||||
|             ('value__h', True), | ||||
|             ('value__i', False), | ||||
|             ('value__j', None), | ||||
|             ('value__k', {'l': 'm'}), | ||||
|             ('value__n', [None]), | ||||
|             ('value__p', 4.2), | ||||
|         ] | ||||
|         for lookup, expected in tests: | ||||
|             with self.subTest(lookup=lookup): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user