Refs #32779 -- Changed DatabaseSchemaEditor._unique_sql()/_create_unique_sql() to take fields as second parameter.

This commit is contained in:
Hannes Ljungberg 2021-05-27 21:35:24 +02:00 committed by Mariusz Felisiak
parent 22da686ca9
commit b746596f5f
4 changed files with 16 additions and 12 deletions

View File

@ -151,9 +151,9 @@ class BaseDatabaseSchemaEditor:
"""Take a model and return its table definition."""
# Add any unique_togethers (always deferred, as some fields might be
# created afterwards, like geometry fields with some backends).
for fields in model._meta.unique_together:
columns = [model._meta.get_field(field).column for field in fields]
self.deferred_sql.append(self._create_unique_sql(model, columns))
for field_names in model._meta.unique_together:
fields = [model._meta.get_field(field) for field in field_names]
self.deferred_sql.append(self._create_unique_sql(model, fields))
# Create column SQL, add FK deferreds if needed.
column_sqls = []
params = []
@ -407,9 +407,9 @@ class BaseDatabaseSchemaEditor:
for fields in olds.difference(news):
self._delete_composed_index(model, fields, {'unique': True}, self.sql_delete_unique)
# Created uniques
for fields in news.difference(olds):
columns = [model._meta.get_field(field).column for field in fields]
self.execute(self._create_unique_sql(model, columns))
for field_names in news.difference(olds):
fields = [model._meta.get_field(field) for field in field_names]
self.execute(self._create_unique_sql(model, fields))
def alter_index_together(self, model, old_index_together, new_index_together):
"""
@ -790,7 +790,7 @@ class BaseDatabaseSchemaEditor:
self._delete_primary_key(model, strict)
# Added a unique?
if self._unique_should_be_added(old_field, new_field):
self.execute(self._create_unique_sql(model, [new_field.column]))
self.execute(self._create_unique_sql(model, [new_field]))
# Added an index? Add an index if db_index switched to True or a unique
# constraint will no longer be used in lieu of an index. The following
# lines from the truth table show all True cases; the rest are False:
@ -1214,7 +1214,7 @@ class BaseDatabaseSchemaEditor:
self.deferred_sql.append(sql)
return None
constraint = self.sql_unique_constraint % {
'columns': ', '.join(map(self.quote_name, fields)),
'columns': ', '.join([self.quote_name(field.column) for field in fields]),
'deferrable': self._deferrable_constraint_sql(deferrable),
}
return self.sql_constraint % {
@ -1223,7 +1223,7 @@ class BaseDatabaseSchemaEditor:
}
def _create_unique_sql(
self, model, columns, name=None, condition=None, deferrable=None,
self, model, fields, name=None, condition=None, deferrable=None,
include=None, opclasses=None, expressions=None,
):
if (
@ -1242,6 +1242,7 @@ class BaseDatabaseSchemaEditor:
compiler = Query(model, alias_cols=False).get_compiler(connection=self.connection)
table = model._meta.db_table
columns = [field.column for field in fields]
if name is None:
name = IndexName(table, columns, '_uniq', create_unique_name)
else:

View File

@ -187,7 +187,7 @@ class UniqueConstraint(BaseConstraint):
)
def constraint_sql(self, model, schema_editor):
fields = [model._meta.get_field(field_name).column for field_name in self.fields]
fields = [model._meta.get_field(field_name) for field_name in self.fields]
include = [model._meta.get_field(field_name).column for field_name in self.include]
condition = self._get_condition_sql(model, schema_editor)
expressions = self._get_index_expressions(model, schema_editor)
@ -198,7 +198,7 @@ class UniqueConstraint(BaseConstraint):
)
def create_sql(self, model, schema_editor):
fields = [model._meta.get_field(field_name).column for field_name in self.fields]
fields = [model._meta.get_field(field_name) for field_name in self.fields]
include = [model._meta.get_field(field_name).column for field_name in self.include]
condition = self._get_condition_sql(model, schema_editor)
expressions = self._get_index_expressions(model, schema_editor)

View File

@ -321,6 +321,9 @@ backends.
``iso_year`` argument in order to support bounds for ISO-8601 week-numbering
years.
* The second argument of ``DatabaseSchemaEditor._unique_sql()`` and
``_create_unique_sql()`` methods is now fields instead of columns.
:mod:`django.contrib.gis`
-------------------------

View File

@ -3287,7 +3287,7 @@ class SchemaTests(TransactionTestCase):
constraint_name = 'CamelCaseUniqConstraint'
expected_constraint_name = identifier_converter(constraint_name)
editor.execute(editor._create_unique_sql(model, [field.column], constraint_name))
editor.execute(editor._create_unique_sql(model, [field], constraint_name))
self.assertIn(expected_constraint_name, self.get_constraints(model._meta.db_table))
editor.alter_field(model, get_field(unique=True), field, strict=True)
self.assertNotIn(expected_constraint_name, self.get_constraints(model._meta.db_table))