Skip to content

Commit f5cec10

Browse files
committed
implement SchemaEditor.alter_index_together()
1 parent eef69c3 commit f5cec10

File tree

2 files changed

+12
-4
lines changed

2 files changed

+12
-4
lines changed

django_mongodb/features.py

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -93,9 +93,6 @@ class DatabaseFeatures(BaseDatabaseFeatures):
9393
# AlterField (unique)
9494
"schema.tests.SchemaTests.test_unique",
9595
"schema.tests.SchemaTests.test_unique_and_reverse_m2m",
96-
# alter_index_together
97-
"migrations.test_operations.OperationTests.test_alter_index_together",
98-
"schema.tests.SchemaTests.test_index_together",
9996
# alter_unique_together
10097
"migrations.test_operations.OperationTests.test_alter_unique_together",
10198
"schema.tests.SchemaTests.test_unique_together",

django_mongodb/schema.py

Lines changed: 12 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -89,7 +89,18 @@ def remove_field(self, model, field):
8989
self.connection.database[model._meta.db_table].update_many({}, {"$unset": {column: ""}})
9090

9191
def alter_index_together(self, model, old_index_together, new_index_together):
92-
pass
92+
olds = {tuple(fields) for fields in old_index_together}
93+
news = {tuple(fields) for fields in new_index_together}
94+
# Deleted indexes
95+
for field_names in olds.difference(news):
96+
idx = Index(fields=field_names)
97+
idx.set_name_with_model(model)
98+
self.remove_index(model, idx)
99+
# Created indexes
100+
for field_names in news.difference(olds):
101+
idx = Index(fields=field_names)
102+
idx.set_name_with_model(model)
103+
self.add_index(model, idx)
93104

94105
def alter_unique_together(self, model, old_unique_together, new_unique_together):
95106
pass

0 commit comments

Comments
 (0)