mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	Fixed #36612 -- Fixed a KeyTextTransform crash on MySQL against annotations.
MySQL only supports the ->> when used directly against columns, this can be inferred by the presence of lhs.output_field.model as model bounds fields are directly tied to columns. Purposely don't systematically switch to using JSON_QUOTE(JSON_EXTRACT(...)) as there might be functional indices out there that rely on the SQL remaining stable between versions. Thanks Jacob Tavener for the report.
This commit is contained in:
		
				
					committed by
					
						 Sarah Boyce
						Sarah Boyce
					
				
			
			
				
	
			
			
			
						parent
						
							a36df6890d
						
					
				
				
					commit
					af84cfba59
				
			| @@ -1160,6 +1160,12 @@ class TestQuerying(TestCase): | ||||
|                     True, | ||||
|                 ) | ||||
|  | ||||
|     def test_cast_with_key_text_transform(self): | ||||
|         obj = NullableJSONModel.objects.annotate( | ||||
|             json_data=Cast(Value({"foo": "bar"}, JSONField()), JSONField()) | ||||
|         ).get(pk=self.objs[0].pk, json_data__foo__icontains="bar") | ||||
|         self.assertEqual(obj, self.objs[0]) | ||||
|  | ||||
|     @skipUnlessDBFeature("supports_json_field_contains") | ||||
|     def test_contains_contained_by_with_key_transform(self): | ||||
|         tests = [ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user