mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[2.0.x] Fixed #28596 -- Fixed QuerySet.bulk_create() and cascade deletion crash on Oracle when using more than 65535 parameters.
Thanks Tim Graham for the review.
Backport of 1b823b8f18 from master
			
			
This commit is contained in:
		| @@ -55,3 +55,4 @@ class DatabaseFeatures(BaseDatabaseFeatures): | |||||||
|     """ |     """ | ||||||
|     supports_callproc_kwargs = True |     supports_callproc_kwargs = True | ||||||
|     supports_over_clause = True |     supports_over_clause = True | ||||||
|  |     max_query_params = 2**16 - 1 | ||||||
|   | |||||||
| @@ -553,3 +553,9 @@ END; | |||||||
|             rhs_sql, rhs_params = rhs |             rhs_sql, rhs_params = rhs | ||||||
|             return "NUMTODSINTERVAL(%s - %s, 'DAY')" % (lhs_sql, rhs_sql), lhs_params + rhs_params |             return "NUMTODSINTERVAL(%s - %s, 'DAY')" % (lhs_sql, rhs_sql), lhs_params + rhs_params | ||||||
|         return super().subtract_temporals(internal_type, lhs, rhs) |         return super().subtract_temporals(internal_type, lhs, rhs) | ||||||
|  |  | ||||||
|  |     def bulk_batch_size(self, fields, objs): | ||||||
|  |         """Oracle restricts the number of parameters in a query.""" | ||||||
|  |         if fields: | ||||||
|  |             return self.connection.features.max_query_params // len(fields) | ||||||
|  |         return len(objs) | ||||||
|   | |||||||
| @@ -9,3 +9,17 @@ class OperationsTests(unittest.TestCase): | |||||||
|     def test_sequence_name_truncation(self): |     def test_sequence_name_truncation(self): | ||||||
|         seq_name = connection.ops._get_no_autofield_sequence_name('schema_authorwithevenlongee869') |         seq_name = connection.ops._get_no_autofield_sequence_name('schema_authorwithevenlongee869') | ||||||
|         self.assertEqual(seq_name, 'SCHEMA_AUTHORWITHEVENLOB0B8_SQ') |         self.assertEqual(seq_name, 'SCHEMA_AUTHORWITHEVENLOB0B8_SQ') | ||||||
|  |  | ||||||
|  |     def test_bulk_batch_size(self): | ||||||
|  |         # Oracle restricts the number of parameters in a query. | ||||||
|  |         objects = range(2**16) | ||||||
|  |         self.assertEqual(connection.ops.bulk_batch_size([], objects), len(objects)) | ||||||
|  |         # Each field is a parameter for each object. | ||||||
|  |         self.assertEqual( | ||||||
|  |             connection.ops.bulk_batch_size(['id'], objects), | ||||||
|  |             connection.features.max_query_params, | ||||||
|  |         ) | ||||||
|  |         self.assertEqual( | ||||||
|  |             connection.ops.bulk_batch_size(['id', 'other'], objects), | ||||||
|  |             connection.features.max_query_params // 2, | ||||||
|  |         ) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user