Fixed #12400 -- Allowed geometry fields in unique_together
Thanks Tim Graham for the review.
This commit is contained in:
parent
b4da88b126
commit
01ec127bae
|
@ -31,7 +31,6 @@ class BaseDatabaseSchemaEditor(object):
|
||||||
|
|
||||||
# Overrideable SQL templates
|
# Overrideable SQL templates
|
||||||
sql_create_table = "CREATE TABLE %(table)s (%(definition)s)"
|
sql_create_table = "CREATE TABLE %(table)s (%(definition)s)"
|
||||||
sql_create_table_unique = "UNIQUE (%(columns)s)"
|
|
||||||
sql_rename_table = "ALTER TABLE %(old_table)s RENAME TO %(new_table)s"
|
sql_rename_table = "ALTER TABLE %(old_table)s RENAME TO %(new_table)s"
|
||||||
sql_retablespace_table = "ALTER TABLE %(table)s SET TABLESPACE %(new_tablespace)s"
|
sql_retablespace_table = "ALTER TABLE %(table)s SET TABLESPACE %(new_tablespace)s"
|
||||||
sql_delete_table = "DROP TABLE %(table)s CASCADE"
|
sql_delete_table = "DROP TABLE %(table)s CASCADE"
|
||||||
|
@ -263,12 +262,11 @@ class BaseDatabaseSchemaEditor(object):
|
||||||
if autoinc_sql:
|
if autoinc_sql:
|
||||||
self.deferred_sql.extend(autoinc_sql)
|
self.deferred_sql.extend(autoinc_sql)
|
||||||
|
|
||||||
# Add any unique_togethers
|
# 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:
|
for fields in model._meta.unique_together:
|
||||||
columns = [model._meta.get_field(field).column for field in fields]
|
columns = [model._meta.get_field(field).column for field in fields]
|
||||||
column_sqls.append(self.sql_create_table_unique % {
|
self.deferred_sql.append(self._create_unique_sql(model, columns))
|
||||||
"columns": ", ".join(self.quote_name(column) for column in columns),
|
|
||||||
})
|
|
||||||
# Make the table
|
# Make the table
|
||||||
sql = self.sql_create_table % {
|
sql = self.sql_create_table % {
|
||||||
"table": self.quote_name(model._meta.db_table),
|
"table": self.quote_name(model._meta.db_table),
|
||||||
|
|
|
@ -13,6 +13,8 @@ class DatabaseSchemaEditor(BaseDatabaseSchemaEditor):
|
||||||
|
|
||||||
sql_delete_table = "DROP TABLE %(table)s"
|
sql_delete_table = "DROP TABLE %(table)s"
|
||||||
sql_create_inline_fk = "REFERENCES %(to_table)s (%(to_column)s)"
|
sql_create_inline_fk = "REFERENCES %(to_table)s (%(to_column)s)"
|
||||||
|
sql_create_unique = "CREATE UNIQUE INDEX %(name)s ON %(table)s (%(columns)s)"
|
||||||
|
sql_delete_unique = "DROP INDEX %(name)s"
|
||||||
|
|
||||||
def __enter__(self):
|
def __enter__(self):
|
||||||
with self.connection.cursor() as c:
|
with self.connection.cursor() as c:
|
||||||
|
|
|
@ -57,6 +57,9 @@ class MultiFields(NamedModel):
|
||||||
point = models.PointField()
|
point = models.PointField()
|
||||||
poly = models.PolygonField()
|
poly = models.PolygonField()
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
unique_together = ('city', 'point')
|
||||||
|
|
||||||
|
|
||||||
class Truth(models.Model):
|
class Truth(models.Model):
|
||||||
val = models.BooleanField(default=False)
|
val = models.BooleanField(default=False)
|
||||||
|
|
Loading…
Reference in New Issue