{
  "original_problem": {
    "instance_id": "django__django-15695",
    "repo": "django/django",
    "created_at": "2022-05-16T07:58:51Z",
    "problem_statement": "RenameIndex() crashes when unnamed index is moving backward and forward.\nDescription\n\t\nRenameIndex() should restore the old auto-generated name when an unnamed index for unique_together is moving backward. Now re-applying RenameIndex() crashes. For example:\ntests/migrations/test_operations.py\ndiff --git a/tests/migrations/test_operations.py b/tests/migrations/test_operations.py\nindex cfd28b1b39..c0a55023bb 100644\n\t\t\t\t\t\n\t\t\t\t\t a\n\t\t\t\t \n\t\t\t\t\t\n\t\t\t\t\t b\n\t\t\t\t \n class OperationTests(OperationTestBase): \n29882988        with connection.schema_editor() as editor, self.assertNumQueries(0):\n29892989            operation.database_backwards(app_label, editor, new_state, project_state)\n29902990        self.assertIndexNameExists(table_name, \"new_pony_test_idx\")\n 2991        # Re-apply renaming.\n 2992        with connection.schema_editor() as editor:\n 2993            operation.database_forwards(app_label, editor, project_state, new_state)\n 2994        self.assertIndexNameExists(table_name, \"new_pony_test_idx\")\n29912995        # Deconstruction.\n29922996        definition = operation.deconstruct()\n29932997        self.assertEqual(definition[0], \"RenameIndex\")\ncrashes on PostgreSQL:\ndjango.db.utils.ProgrammingError: relation \"new_pony_test_idx\" already exists\n",
    "patch": "diff --git a/django/db/migrations/operations/models.py b/django/db/migrations/operations/models.py\n--- a/django/db/migrations/operations/models.py\n+++ b/django/db/migrations/operations/models.py\n@@ -960,6 +960,9 @@ def database_forwards(self, app_label, schema_editor, from_state, to_state):\n         else:\n             from_model_state = from_state.models[app_label, self.model_name_lower]\n             old_index = from_model_state.get_index_by_name(self.old_name)\n+        # Don't alter when the index name is not changed.\n+        if old_index.name == self.new_name:\n+            return\n \n         to_model_state = to_state.models[app_label, self.model_name_lower]\n         new_index = to_model_state.get_index_by_name(self.new_name)\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_33080",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with nullability changes and not index renaming or handling, lacking transferable reasoning."
      },
      {
        "idx": 2,
        "id": "similar_29827",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about test database reuse inefficiencies, unrelated to index renaming or handling."
      },
      {
        "idx": 3,
        "id": "similar_26171",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves index creation logic for foreign keys, not renaming or handling of existing indexes."
      },
      {
        "idx": 4,
        "id": "similar_24757",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve handling of indexes during migrations, with a focus on constraint management and index existence checks."
      },
      {
        "idx": 5,
        "id": "similar_29496",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about primary key constraint conflicts in Oracle, not related to index renaming or handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Changing nullability for fields which allow empty string should not change nullability on Oracle.",
        "issue_body": "Oracle stores empty strings as NULL values and Django has code to handle that, but there is a bug.\nBackground: I just tried using django-silk with an Oracle database as the back end and it was generating errors trying to safe a blank value in a FileField that had blank=True set. The error was: django.db.utils.\nIntegrityError\n:\nORA-01400: cannot insert NULL into (\"MISPORTAL\".\"SILK_REQUEST\".\"PROF_FILE\")\nAs noted Django has code to deal with the fact Oracle stores empty strings as NULL values (and sets char fields as NULL rather than NOT NULL if blank=True), so it shouldn't happen. But looking through the migration history I saw that the schema originally defined the field with null=True and changed it to blank=True later, so there's an AlterField that comes into play where the null attribute on the field has changed.\nFrom a quick skim of the code I believe Django has code to ignore migrations which change whether a column is nullable or not if connection.features.interprets_empty_strings_as_nulls is True but only if the field's\nget_internal_type()\nis\nCharField\nor\nTextField\"\n- that obviously doesn't include\nFileField\n. So although Django will correctly create FileField columns where\nblank=True\nas\nNULL\nunder Oracle, if they were originally\nnull=True\nand are later migrated to just be\nblank=True\nthen Django won't skip changing the column to\nNOT NULL\nand so you'll end up with the column being NOT NULL and empty strings in that field will result in the error as Oracle tries to save them as NULL values.\nThe bit which I think needs changing to fix this is in\ndb/backends/base/schema.py\nand is in\n_alter_column_null_sql\n- I think just adding \"FileField\" to the list should do it. Having said that - I don't know enough about Django's internals but it does seem a little strange that the test in\n_alter_column_null_sql\ndoesn't mirror the test that is in\n_iter_column_sql\nof checking\n(field.empty_strings_allowed and not field.primary_key and self.connection.features.interprets_empty_strings_as_nulls)\nrather than the specific type - although perhaps the test in\n_iter_column_sql\ngot changed in the past and\n_alter_column_null_sql\ngot missed as being altered to match it?",
        "issue_id": 33080,
        "pr_number": 14822,
        "pr_title": "Fixed #33080 -- Preserved nullability of textual fields on Oracle.",
        "pr_body": "ticket-33080",
        "issue_closed_at": "2021-09-01T13:54:48",
        "base_commit": "84c7c4a477eae5de394d036d7ba1e58a37e18b69"
      },
      "summary": "### Summary: \nThis issue pertains to a bug in Django's handling of nullability changes for certain database fields when using Oracle as the backend. Oracle stores empty strings as NULL values, which Django accounts for, but the bug occurs when altering a field's nullability from `null=True` to `blank=True`. The problem arises particularly with `FileField` types, which are not properly managed under these conditions, leading to an `IntegrityError` when attempting to save blank values. The error is due to the field being incorrectly set as `NOT NULL` in the database schema after a migration, despite Oracle's behavior of treating empty strings as NULL.\n\nKey symptoms include errors when saving blank `FileField` values in Oracle databases, traced to a mismatch between the expected and actual nullability settings in the database schema. The affected component is the Django ORM, specifically the schema migration logic within `db/backends/base/schema.py`. \n\nThe potential impact is significant for applications relying on Oracle databases with fields that may transition from `null=True` to `blank=True`, as this could lead to application crashes or data integrity issues. The severity is heightened for applications with fields that store empty strings, as these are directly impacted by the bug.\n\nRelevant technical details include the need to adjust the logic that determines when to alter column nullability in the schema migration process. The fix involves modifying the `_alter_column_null_sql` function in Django's schema editor to account for `FileField` types, ensuring their nullability is handled consistently with `CharField` and `TextField` types. This adjustment aligns the nullability alteration logic with Oracle's handling of empty strings, preventing unintended NOT NULL constraints in the database schema.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Changing nullability for fields which allow empty string should not change nullability on Oracle.\n\nBody:\nOracle stores empty strings as NULL values and Django has code to handle that, but there is a bug.\nBackground: I just tried using django-silk with an Oracle database as the back end and it was generating errors trying to safe a blank value in a FileField that had blank=True set. The error was: django.db.utils.\nIntegrityError\n:\nORA-01400: cannot insert NULL into (\"MISPORTAL\".\"SILK_REQUEST\".\"PROF_FILE\")\nAs noted Django has code to deal with the fact Oracle stores empty strings as NULL values (and sets char fields as NULL rather than NOT NULL if blank=True), so it shouldn't happen. But looking through the migration history I saw that the schema originally defined the field with null=True and changed it to blank=True later, so there's an AlterField that comes into play where the null attribute on the field has changed.\nFrom a quick skim of the code I believe Django has code to ignore migrations which change whether a column is nullable or not if connection.features.interprets_empty_strings_as_nulls is True but only if the field's\nget_internal_type()\nis\nCharField\nor\nTextField\"\n- that obviously doesn't include\nFileField\n. So although Django will correctly create FileField columns where\nblank=True\nas\nNULL\nunder Oracle, if they were originally\nnull=True\nand are later migrated to just be\nblank=True\nthen Django won't skip changing the column to\nNOT NULL\nand so you'll end up with the column being NOT NULL and empty strings in that field will result in the error as Oracle tries to save them as NULL values.\nThe bit which I think needs changing to fix this is in\ndb/backends/base/schema.py\nand is in\n_alter_column_null_sql\n- I think just adding \"FileField\" to the list should do it. Having said that - I don't know enough about Django's internals but it does seem a little strange that the test in\n_alter_column_null_sql\ndoesn't mirror the test that is in\n_iter_column_sql\nof checking\n(field.empty_strings_allowed and not field.primary_key and self.connection.features.interprets_empty_strings_as_nulls)\nrather than the specific type - although perhaps the test in\n_iter_column_sql\ngot changed in the past and\n_alter_column_null_sql\ngot missed as being altered to match it?\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/db/backends/base/schema.py\n  function: BaseDatabaseSchemaEditor._alter_column_null_sql\n"
    },
    {
      "similar_issue": {
        "issue_title": "cloned DBs are not reused during tests on MySQL",
        "issue_body": "When I'm using\ntests/runtests.py --parallel=8 -k\n, I expect following runs to be faster than the prior one, because test DBs are created once and are reused in the following runs. On MySQL they take the same time. I see\nmysqldump\nin processes every time I run tests.\nIt seems that this regression was introduced in\ne1253bc26facfa1d0fca161f43925e99c2591ced\n.",
        "issue_id": 29827,
        "pr_number": 10468,
        "pr_title": "Fixed #29827 -- Fixed reuse of existing test DBs with --keepdb on MySQL.",
        "pr_body": "https://code.djangoproject.com/ticket/29827",
        "issue_closed_at": "2018-10-25T18:38:15",
        "base_commit": "76b3367035889d87ffef7a52cd44d70e30537f6f"
      },
      "summary": "### Summary:\n\nThis issue pertains to inefficiencies in the reuse of cloned test databases during test execution, specifically affecting the MySQL backend. Generally, when tests are run in parallel, the expectation is that subsequent test runs will be faster due to the reuse of previously created test databases. However, the observed behavior on MySQL indicates that each test run takes the same amount of time, suggesting that test databases are being recreated rather than reused. The presence of `mysqldump` processes during each test execution supports this observation.\n\nKey symptoms include consistently long test execution times even after the initial setup, which is contrary to the expected improvement in performance. The problem was identified as a regression associated with a specific commit, impacting the database creation and cloning mechanisms in the MySQL backend of the system.\n\nThe affected components include the database creation methods within the MySQL backend of the application, specifically the functions responsible for creating and cloning test databases. The severity of the issue lies in its impact on test efficiency, potentially leading to longer development cycles and increased resource usage.\n\nFrom a technical perspective, the issue highlights the importance of efficient resource management and the need for proper reuse mechanisms within test environments to optimize performance and reduce redundancy. The problem was addressed by modifying specific functions in the `creation.py` file within the Django MySQL backend, ensuring that cloned test databases are reused as intended.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: cloned DBs are not reused during tests on MySQL\n\nBody:\nWhen I'm using\ntests/runtests.py --parallel=8 -k\n, I expect following runs to be faster than the prior one, because test DBs are created once and are reused in the following runs. On MySQL they take the same time. I see\nmysqldump\nin processes every time I run tests.\nIt seems that this regression was introduced in\ne1253bc26facfa1d0fca161f43925e99c2591ced\n.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/db/backends/mysql/creation.py\n  function: DatabaseCreation.sql_table_creation_suffix\n  function: DatabaseCreation._clone_test_db\n  function: DatabaseCreation._clone_test_db\n"
    },
    {
      "similar_issue": {
        "issue_title": "ForeignKey with db_constraint=False doesn't generate an index on MySQL",
        "issue_body": "I have a model that does not want to use a constraint on a foreign key, but still use a database index:\nclass Category(models.Model):\n    text = models.CharField(max_length=3)\n\nclass Message(models.Model):\n    cat = models.ForeignKey(Category, db_constraint=False)\n\nclass IndexMessage(models.Model):\n    cat = models.ForeignKey(Category, db_constraint=False, db_index=True)\n\nclass StrongMessage(models.Model):\n    cat = models.ForeignKey(Category)\nThe SQLite backend generates an index on the FK column for both models:\n$ python manage.py sqlmigrate boohoo 0001_initial\nBEGIN;\n--\n-- Create model Category\n--\nCREATE TABLE \"boohoo_category\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"text\" varchar(3) NOT NULL);\n--\n-- Create model IndexMessage\n--\nCREATE TABLE \"boohoo_indexmessage\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL);\n--\n-- Create model Message\n--\nCREATE TABLE \"boohoo_message\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL);\n--\n-- Create model StrongMessage\n--\nCREATE TABLE \"boohoo_strongmessage\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL REFERENCES \"boohoo_category\" (\"id\"));\nCREATE INDEX \"boohoo_indexmessage_05e7bb57\" ON \"boohoo_indexmessage\" (\"cat_id\");\nCREATE INDEX \"boohoo_message_05e7bb57\" ON \"boohoo_message\" (\"cat_id\");\nCREATE INDEX \"boohoo_strongmessage_05e7bb57\" ON \"boohoo_strongmessage\" (\"cat_id\");\n\nCOMMIT;\nWith the MySQL backend, this does not create an index on the FK:\n$ python manage.py sqlmigrate boohoo 0001_initial\nBEGIN;\n--\n-- Create model Category\n--\nCREATE TABLE `boohoo_category` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `text` varchar(3) NOT NULL);\n--\n-- Create model IndexMessage\n--\nCREATE TABLE `boohoo_indexmessage` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\n--\n-- Create model Message\n--\nCREATE TABLE `boohoo_message` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\n--\n-- Create model StrongMessage\n--\nCREATE TABLE `boohoo_strongmessage` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\nALTER TABLE `boohoo_strongmessage` ADD CONSTRAINT `boohoo_strongmessage_cat_id_c843b68a_fk_boohoo_category_id` FOREIGN KEY (`cat_id`) REFERENCES `boohoo_category` (`id`);\n\nCOMMIT;\nI would think that specifying db_constraint=false would only leave out the constraint, and not also the index; Especially with <field>.db_index still set to true. Adding db_index=True does not help, probably because that is the default setting on the FK field object.\nThis also applies to earlier django versions.\nA simple workaround is to use\nindex_together = (('cat', ), )\non the models.\nI'm inclined to blame this on django.db.backends.mysql.schema.DatabaseSchemaEditor#_model_indexes_sql,\nwhich may need an extra check for db_constraint being used. This fixes my problem (but changes current django behavior):\n--- django/db/backends/mysql/schema.py.orig     2016-02-03 12:01:10.000000000 +0100\n+++ django/db/backends/mysql/schema.py  2016-02-03 12:00:19.000000000 +0100\n@@ -64,7 +64,7 @@\n         )\n         if storage == \"InnoDB\":\n             for field in model._meta.local_fields:\n-                if field.db_index and not field.unique and field.get_internal_type() == \"ForeignKey\":\n+                if field.db_index and not field.unique and field.get_internal_type() == \"ForeignKey\" and field.db_constraint:\n                     # Temporary setting db_index to False (in memory) to disable\n                     # index creation for FKs (index automatically created by MySQL)\n                     field.db_index = False",
        "issue_id": 26171,
        "pr_number": 6774,
        "pr_title": "Fixed #26171 -- Made MySQL create an index on ForeignKeys with db_contraint=False.",
        "pr_body": "Refactor \"Prevented unneeded index creation on MySQL-InnoDB\" (2ceb10f)\nto avoid setting db_index = False. Check db_constraint=True before\nskipping the index creation, fixes #26171.\n",
        "issue_closed_at": "2016-06-28T07:19:11",
        "base_commit": "5fe1c92250017110430c7c2153cfd8776e4c7064"
      },
      "summary": "### Summary: This issue pertains to the behavior of database indexing in Django models when using the MySQL backend. Specifically, when a ForeignKey field is defined with `db_constraint=False`, the MySQL backend fails to generate an index on the foreign key column, contrary to the behavior observed with the SQLite backend. This discrepancy arises despite the `db_index=True` setting on the field, which is expected to enforce index creation. The issue has been identified in the Django code responsible for handling schema operations in the MySQL backend, suggesting an oversight in the logic that manages index creation when constraints are disabled. This behavior impacts database performance, as indexes are crucial for query optimization and retrieval speed. A workaround involves manually specifying index creation using `index_together`. The issue affects multiple Django versions and indicates a need for code modification in `django.db.backends.mysql.schema.DatabaseSchemaEditor` to correctly account for the `db_constraint` setting when determining index creation. The proposed code fix ensures that indexes are only skipped for foreign keys when `db_constraint` is explicitly set to False, aligning the MySQL behavior with other database backends.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: ForeignKey with db_constraint=False doesn't generate an index on MySQL\n\nBody:\nI have a model that does not want to use a constraint on a foreign key, but still use a database index:\nclass Category(models.Model):\n    text = models.CharField(max_length=3)\n\nclass Message(models.Model):\n    cat = models.ForeignKey(Category, db_constraint=False)\n\nclass IndexMessage(models.Model):\n    cat = models.ForeignKey(Category, db_constraint=False, db_index=True)\n\nclass StrongMessage(models.Model):\n    cat = models.ForeignKey(Category)\nThe SQLite backend generates an index on the FK column for both models:\n$ python manage.py sqlmigrate boohoo 0001_initial\nBEGIN;\n--\n-- Create model Category\n--\nCREATE TABLE \"boohoo_category\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"text\" varchar(3) NOT NULL);\n--\n-- Create model IndexMessage\n--\nCREATE TABLE \"boohoo_indexmessage\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL);\n--\n-- Create model Message\n--\nCREATE TABLE \"boohoo_message\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL);\n--\n-- Create model StrongMessage\n--\nCREATE TABLE \"boohoo_strongmessage\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL REFERENCES \"boohoo_category\" (\"id\"));\nCREATE INDEX \"boohoo_indexmessage_05e7bb57\" ON \"boohoo_indexmessage\" (\"cat_id\");\nCREATE INDEX \"boohoo_message_05e7bb57\" ON \"boohoo_message\" (\"cat_id\");\nCREATE INDEX \"boohoo_strongmessage_05e7bb57\" ON \"boohoo_strongmessage\" (\"cat_id\");\n\nCOMMIT;\nWith the MySQL backend, this does not create an index on the FK:\n$ python manage.py sqlmigrate boohoo 0001_initial\nBEGIN;\n--\n-- Create model Category\n--\nCREATE TABLE `boohoo_category` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `text` varchar(3) NOT NULL);\n--\n-- Create model IndexMessage\n--\nCREATE TABLE `boohoo_indexmessage` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\n--\n-- Create model Message\n--\nCREATE TABLE `boohoo_message` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\n--\n-- Create model StrongMessage\n--\nCREATE TABLE `boohoo_strongmessage` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\nALTER TABLE `boohoo_strongmessage` ADD CONSTRAINT `boohoo_strongmessage_cat_id_c843b68a_fk_boohoo_category_id` FOREIGN KEY (`cat_id`) REFERENCES `boohoo_category` (`id`);\n\nCOMMIT;\nI would think that specifying db_constraint=false would only leave out the constraint, and not also the index; Especially with <field>.db_index still set to true. Adding db_index=True does not help, probably because that is the default setting on the FK field object.\nThis also applies to earlier django versions.\nA simple workaround is to use\nindex_together = (('cat', ), )\non the models.\nI'm inclined to blame this on django.db.backends.mysql.schema.DatabaseSchemaEditor#_model_indexes_sql,\nwhich may need an extra check for db_constraint being used. This fixes my problem (but changes current django behavior):\n--- django/db/backends/mysql/schema.py.orig     2016-02-03 12:01:10.000000000 +0100\n+++ django/db/backends/mysql/schema.py  2016-02-03 12:00:19.000000000 +0100\n@@ -64,7 +64,7 @@\n         )\n         if storage == \"InnoDB\":\n             for field in model._meta.local_fields:\n-                if field.db_index and not field.unique and field.get_internal_type() == \"ForeignKey\":\n+                if field.db_index and not field.unique and field.get_internal_type() == \"ForeignKey\" and field.db_constraint:\n                     # Temporary setting db_index to False (in memory) to disable\n                     # index creation for FKs (index automatically created by MySQL)\n                     field.db_index = False\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/db/backends/base/schema.py\n  function: BaseDatabaseSchemaEditor._model_indexes_sql\n  function: BaseDatabaseSchemaEditor._model_indexes_sql\n\ndjango/db/backends/mysql/schema.py\n  function: DatabaseSchemaEditor.add_field\n"
    },
    {
      "similar_issue": {
        "issue_title": "Removing unique_together constraint make Django 1.8 migration fail with MySQL",
        "issue_body": "Migrations containing\nmigrations.AlterUniqueTogether(name='xxx', unique_together=set([]),)\nmay fail on Django 1.8 but not on Django 1.7 if using the backend mysql.\nGiven the database engine is mysql and the following\nmodels.py\n:\nfrom django.db import models\n\n\nclass MyModelA(models.Model):\n    s = models.CharField(max_length=120)\n\n\nclass MyModelB(models.Model):\n    a = models.ForeignKey(MyModelA)\n    b = models.IntegerField()\nAnd the 2 following migrations:\n# -*- coding: utf-8 -*-\nfrom __future__ import unicode_literals\n\nfrom django.db import models, migrations\n\n\nclass Migration(migrations.Migration):\n\n    dependencies = [\n    ]\n\n    operations = [\n        migrations.CreateModel(\n            name='MyModelA',\n            fields=[\n                ('id', models.AutoField(serialize=False, auto_created=True, verbose_name='ID', primary_key=True)),\n                ('s', models.CharField(max_length=120)),\n            ],\n        ),\n        migrations.CreateModel(\n            name='MyModelB',\n            fields=[\n                ('id', models.AutoField(serialize=False, auto_created=True, verbose_name='ID', primary_key=True)),\n                ('b', models.IntegerField()),\n                ('a', models.ForeignKey(to='mysite.MyModelA')),\n            ],\n        ),\n        migrations.AlterUniqueTogether(\n            name='mymodelb',\n            unique_together=set([('a', 'b')]),\n        ),\n    ]\n# -*- coding: utf-8 -*-\nfrom __future__ import unicode_literals\n\nfrom django.db import models, migrations\n\n\nclass Migration(migrations.Migration):\n\n    dependencies = [\n        ('mysite', '0001_initial'),\n    ]\n\n    operations = [\n        migrations.AlterUniqueTogether(\n            name='mymodelb',\n            unique_together=set([]),\n        ),\n    ]\nRunning\n./manage.py migrate\nworks fine on Django 1.7, but on Django 1.8 I get the following error:\n$ ./manage.py migrate                \nOperations to perform:\n  Synchronize unmigrated apps: staticfiles, messages\n  Apply all migrations: contenttypes, auth, mysite, sessions, admin\nSynchronizing apps without migrations:\n  Creating tables...\n    Running deferred SQL...\n  Installing custom SQL...\nRunning migrations:\n  Rendering model states... DONE\n  [..]\n  Applying mysite.0001_initial... OK\n  Applying mysite.0002_auto...Traceback (most recent call last):\n  [..]\ndjango.db.utils.OperationalError: (1553, \"Cannot drop index 'mysite_mymodelb_a_id_b53c781c93aab9a_uniq': needed in a foreign key constraint\")\nThe same migrations work on psql, I did not have the chance to test it against sqlite.\nInspecting the generated sql I found Django 1.7 add an index in addition to the unique constraint and Django 1.8 does not.\nOn Django 1.7\nBEGIN;\nCREATE TABLE `mysite_mymodela` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `s` varchar(120) NOT NULL);\nCREATE TABLE `mysite_mymodelb` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `b` integer NOT NULL, `a_id` integer NOT NULL);\nALTER TABLE `mysite_mymodelb` ADD CONSTRAINT `mysite_mymodelb_a_id_48275010b87402ed_uniq` UNIQUE (`a_id`, `b`);\nALTER TABLE `mysite_mymodelb` ADD CONSTRAINT `mysite_mymodelb_a_id_4981d3920f0fef1e_fk_mysite_mymodela_id` FOREIGN KEY (`a_id`) REFERENCES `mysite_mymodela` (`id`);\nCREATE INDEX `mysite_mymodelb_e2b453f4` ON `mysite_mymodelb` (`a_id`);\n\nCOMMIT;\nNote the\nCREATE INDEX `mysite_mymodelb_e2b453f4` ON `mysite_mymodelb` (`a_id`);\n.\nAnd on Django 1.8\nBEGIN;\nCREATE TABLE `mysite_mymodela` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `s` varchar(120) NOT NULL);\nCREATE TABLE `mysite_mymodelb` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `b` integer NOT NULL, `a_id` integer NOT NULL);\nALTER TABLE `mysite_mymodelb` ADD CONSTRAINT `mysite_mymodelb_a_id_784bb266d0e363ab_uniq` UNIQUE (`a_id`, `b`);\nALTER TABLE `mysite_mymodelb` ADD CONSTRAINT `mysite_mymodelb_a_id_50892c78e36678b8_fk_mysite_mymodela_id` FOREIGN KEY (`a_id`) REFERENCES `mysite_mymodela` (`id`);\n\nCOMMIT;\nI joined the full traceback.",
        "issue_id": 24757,
        "pr_number": 4655,
        "pr_title": "Fixed #24757 -- Recreated MySQL index when needed during unique_together removal",
        "pr_body": "",
        "issue_closed_at": "2015-05-15T10:06:22",
        "base_commit": "0eaef8e527af556c0c517a64035929404cf94a39"
      },
      "summary": "### Summary:\nThis issue involves a migration failure when removing a `unique_together` constraint in Django 1.8 when using MySQL as the database backend. The problem does not occur in Django 1.7, indicating a change in behavior between these versions. The failure is specific to the MySQL database engine and is related to how Django manages database indexes and constraints during migrations.\n\n1. **Problem description in general terms:**\n   The issue arises when attempting to apply migrations that alter the `unique_together` constraint for a model in a Django application using MySQL. Specifically, the migration involves removing a `unique_together` constraint, which leads to an error due to an index being required by a foreign key constraint.\n\n2. **Key symptoms and behaviors observed:**\n   The primary symptom is an `OperationalError` encountered during the migration process in Django 1.8, which does not occur in Django 1.7. The error message indicates an inability to drop an index that is needed for a foreign key constraint. This suggests a discrepancy in how Django versions handle index creation and management for constraints.\n\n3. **Affected components or systems:**\n   - The Django migration system, specifically related to the management of `unique_together` constraints.\n   - MySQL database engine, where the issue manifests due to differences in index handling.\n\n4. **Potential impact or severity:**\n   The impact is significant for developers migrating Django applications from version 1.7 to 1.8 using MySQL, as it prevents successful application of migrations. This can halt development and deployment processes, posing a risk to project timelines and stability.\n\n5. **Relevant technical details abstracted for broader understanding:**\n   - In Django 1.7, an additional index is created alongside the `unique_together` constraint, which is not the case in Django 1.8. This change in behavior leads to the migration failure in MySQL.\n   - The error does not occur with PostgreSQL (psql), suggesting that the issue is specific to MySQL's handling of indexes and constraints.\n   - The patch addresses the issue by modifying functions responsible for altering unique constraints and managing model indexes within Django's schema editor for MySQL.\n\nChanges were made to the following code elements:\n- `django/db/backends/base/schema.py`, specifically the `alter_unique_together` and `alter_index_together` functions.\n- `django/db/backends/mysql/schema.py`, particularly in the `_model_indexes_sql` function.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Removing unique_together constraint make Django 1.8 migration fail with MySQL\n\nBody:\nMigrations containing\nmigrations.AlterUniqueTogether(name='xxx', unique_together=set([]),)\nmay fail on Django 1.8 but not on Django 1.7 if using the backend mysql.\nGiven the database engine is mysql and the following\nmodels.py\n:\nfrom django.db import models\n\n\nclass MyModelA(models.Model):\n    s = models.CharField(max_length=120)\n\n\nclass MyModelB(models.Model):\n    a = models.ForeignKey(MyModelA)\n    b = models.IntegerField()\nAnd the 2 following migrations:\n# -*- coding: utf-8 -*-\nfrom __future__ import unicode_literals\n\nfrom django.db import models, migrations\n\n\nclass Migration(migrations.Migration):\n\n    dependencies = [\n    ]\n\n    operations = [\n        migrations.CreateModel(\n            name='MyModelA',\n            fields=[\n                ('id', models.AutoField(serialize=False, auto_created=True, verbose_name='ID', primary_key=True)),\n                ('s', models.CharField(max_length=120)),\n            ],\n        ),\n        migrations.CreateModel(\n            name='MyModelB',\n            fields=[\n                ('id', models.AutoField(serialize=False, auto_created=True, verbose_name='ID', primary_key=True)),\n                ('b', models.IntegerField()),\n                ('a', models.ForeignKey(to='mysite.MyModelA')),\n            ],\n        ),\n        migrations.AlterUniqueTogether(\n            name='mymodelb',\n            unique_together=set([('a', 'b')]),\n        ),\n    ]\n# -*- coding: utf-8 -*-\nfrom __future__ import unicode_literals\n\nfrom django.db import models, migrations\n\n\nclass Migration(migrations.Migration):\n\n    dependencies = [\n        ('mysite', '0001_initial'),\n    ]\n\n    operations = [\n        migrations.AlterUniqueTogether(\n            name='mymodelb',\n            unique_together=set([]),\n        ),\n    ]\nRunning\n./manage.py migrate\nworks fine on Django 1.7, but on Django 1.8 I get the following error:\n$ ./manage.py migrate                \nOperations to perform:\n  Synchronize unmigrated apps: staticfiles, messages\n  Apply all migrations: contenttypes, auth, mysite, sessions, admin\nSynchronizing apps without migrations:\n  Creating tables...\n    Running deferred SQL...\n  Installing custom SQL...\nRunning migrations:\n  Rendering model states... DONE\n  [..]\n  Applying mysite.0001_initial... OK\n  Applying mysite.0002_auto...Traceback (most recent call last):\n  [..]\ndjango.db.utils.OperationalError: (1553, \"Cannot drop index 'mysite_mymodelb_a_id_b53c781c93aab9a_uniq': needed in a foreign key constraint\")\nThe same migrations work on psql, I did not have the chance to test it against sqlite.\nInspecting the generated sql I found Django 1.7 add an index in addition to the unique constraint and Django 1.8 does not.\nOn Django 1.7\nBEGIN;\nCREATE TABLE `mysite_mymodela` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `s` varchar(120) NOT NULL);\nCREATE TABLE `mysite_mymodelb` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `b` integer NOT NULL, `a_id` integer NOT NULL);\nALTER TABLE `mysite_mymodelb` ADD CONSTRAINT `mysite_mymodelb_a_id_48275010b87402ed_uniq` UNIQUE (`a_id`, `b`);\nALTER TABLE `mysite_mymodelb` ADD CONSTRAINT `mysite_mymodelb_a_id_4981d3920f0fef1e_fk_mysite_mymodela_id` FOREIGN KEY (`a_id`) REFERENCES `mysite_mymodela` (`id`);\nCREATE INDEX `mysite_mymodelb_e2b453f4` ON `mysite_mymodelb` (`a_id`);\n\nCOMMIT;\nNote the\nCREATE INDEX `mysite_mymodelb_e2b453f4` ON `mysite_mymodelb` (`a_id`);\n.\nAnd on Django 1.8\nBEGIN;\nCREATE TABLE `mysite_mymodela` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `s` varchar(120) NOT NULL);\nCREATE TABLE `mysite_mymodelb` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `b` integer NOT NULL, `a_id` integer NOT NULL);\nALTER TABLE `mysite_mymodelb` ADD CONSTRAINT `mysite_mymodelb_a_id_784bb266d0e363ab_uniq` UNIQUE (`a_id`, `b`);\nALTER TABLE `mysite_mymodelb` ADD CONSTRAINT `mysite_mymodelb_a_id_50892c78e36678b8_fk_mysite_mymodela_id` FOREIGN KEY (`a_id`) REFERENCES `mysite_mymodela` (`id`);\n\nCOMMIT;\nI joined the full traceback.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/db/backends/base/schema.py\n  function: BaseDatabaseSchemaEditor.alter_unique_together\n  function: BaseDatabaseSchemaEditor.alter_index_together\n\ndjango/db/backends/mysql/schema.py\n  function: DatabaseSchemaEditor._model_indexes_sql\n"
    },
    {
      "similar_issue": {
        "issue_title": "Altering non-unique field to primary key fails on Oracle",
        "issue_body": "I am trying to migrate a table from an auto-incrementing Integer PK to a UUID PK.\nI have custom-written migrations that add the new UUID field, add new foreign key fields in dependent tables, populate them, remove the old FKs, etc.\nOne of the final steps of the process is to alter the new uuid field in the table to be a primary_key:\nmigrations\n.\nAlterField\n(\nmodel_name\n=\n'examplelayout'\n,\nname\n=\n'uuid'\n,\nfield\n=\nmodels\n.\nUUIDField\n(\ndefault\n=\nuuid\n.\nuuid4\n,\nprimary_key\n=\nTrue\n,\neditable\n=\nFalse\n),\n),\nThe whole process works great on Postgres, but this specific step ends up in an error on Oracle 12, despite the fact that before this step there are no indexes in the DB on this field.\nquery = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT \"VARIO_EXA_UUID_8498C9C8_P\" PRIMARY KEY (\"UUID\")'\n...\ndjango.db.utils.DatabaseError: ORA-02261: such unique or primary key already exists in the table\nThe issue seems to be that Django tries to first add a UNIQUE constraint for the field, then a PRIMARY KEY on the same field. Here are all the SQL queries executed by this specific migration step:\n==================== STEP =========================  4  =====================\n\n\n[2018-06-15 08:51:11.141 | DEBUG | django.db.backends.schema:124] ALTER TABLE \"VARIO_EXAMPLELAYOUT\" MODIFY \"UUID\" DEFAULT '9cf3fe16f11d4fa09b62e337c50ae5f7'; (params [])\n[2018-06-15 08:51:11.212 | DEBUG | django.db.backends:111] (0.071) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" MODIFY \"UUID\" DEFAULT \\'9cf3fe16f11d4fa09b62e337c50ae5f7\\'' - PARAMS = (); args=[]\n[2018-06-15 08:51:11.212 | DEBUG | django.db.backends.schema:124] UPDATE \"VARIO_EXAMPLELAYOUT\" SET \"UUID\" = %s WHERE \"UUID\" IS NULL; (params ['347ac08714bd4c208ffd2f79e7932bb3'])\n[2018-06-15 08:51:11.269 | DEBUG | django.db.backends:111] (0.056) QUERY = 'UPDATE \"VARIO_EXAMPLELAYOUT\" SET \"UUID\" = :arg0 WHERE \"UUID\" IS NULL' - PARAMS = ('347ac08714bd4c208ffd2f79e7932bb3',); args=['347ac08714bd4c208ffd2f79e7932bb3']\n[2018-06-15 08:51:11.269 | DEBUG | django.db.backends.schema:124] ALTER TABLE \"VARIO_EXAMPLELAYOUT\" MODIFY \"UUID\" NOT NULL; (params [])\n[2018-06-15 08:51:11.343 | DEBUG | django.db.backends:111] (0.073) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" MODIFY \"UUID\" NOT NULL' - PARAMS = (); args=[]\n[2018-06-15 08:51:11.343 | DEBUG | django.db.backends.schema:124] ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT vario_exa_uuid_8498c9c8_u UNIQUE (\"UUID\"); (params ())\n[2018-06-15 08:51:11.437 | DEBUG | django.db.backends:111] (0.094) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT vario_exa_uuid_8498c9c8_u UNIQUE (\"UUID\")' - PARAMS = (); args=()\n[2018-06-15 08:51:11.792 | DEBUG | django.db.backends:111] (0.354) QUERY = \"\\n            SELECT\\n                user_constraints.constraint_name,\\n                LISTAGG(LOWER(cols.column_name), ',') WITHIN GROUP (ORDER BY cols.position),\\n                CASE user_constraints.constraint_type\\n                    WHEN 'P' THEN 1\\n                    ELSE 0\\n                END AS is_primary_key,\\n                CASE\\n                    WHEN user_constraints.constraint_type IN ('P', 'U') THEN 1\\n                    ELSE 0\\n                END AS is_unique,\\n                CASE user_constraints.constraint_type\\n                    WHEN 'C' THEN 1\\n                    ELSE 0\\n                END AS is_check_constraint\\n            FROM\\n                user_constraints\\n            LEFT OUTER JOIN\\n                user_cons_columns cols ON user_constraints.constraint_name = cols.constraint_name\\n            WHERE\\n                user_constraints.constraint_type = ANY('P', 'U', 'C')\\n                AND user_constraints.table_name = UPPER(:arg0)\\n            GROUP BY user_constraints.constraint_name, user_constraints.constraint_type\\n        \" - PARAMS = ('vario_examplelayout',); args=['vario_examplelayout']\n[2018-06-15 08:51:12.480 | DEBUG | django.db.backends:111] (0.688) QUERY = \"\\n            SELECT\\n                cons.constraint_name,\\n                LISTAGG(LOWER(cols.column_name), ',') WITHIN GROUP (ORDER BY cols.position),\\n                LOWER(rcols.table_name),\\n                LOWER(rcols.column_name)\\n            FROM\\n                user_constraints cons\\n            INNER JOIN\\n                user_cons_columns rcols ON rcols.constraint_name = cons.r_constraint_name AND rcols.position = 1\\n            LEFT OUTER JOIN\\n                user_cons_columns cols ON cons.constraint_name = cols.constraint_name\\n            WHERE\\n                cons.constraint_type = 'R' AND\\n                cons.table_name = UPPER(:arg0)\\n            GROUP BY cons.constraint_name, rcols.table_name, rcols.column_name\\n        \" - PARAMS = ('vario_examplelayout',); args=['vario_examplelayout']\n[2018-06-15 08:51:13.695 | DEBUG | django.db.backends:111] (1.214) QUERY = \"\\n            SELECT\\n                ind.index_name,\\n                LOWER(ind.index_type),\\n                LISTAGG(LOWER(cols.column_name), ',') WITHIN GROUP (ORDER BY cols.column_position),\\n                LISTAGG(cols.descend, ',') WITHIN GROUP (ORDER BY cols.column_position)\\n            FROM\\n                user_ind_columns cols, user_indexes ind\\n            WHERE\\n                cols.table_name = UPPER(:arg0) AND\\n                NOT EXISTS (\\n                    SELECT 1\\n                    FROM user_constraints cons\\n                    WHERE ind.index_name = cons.index_name\\n                ) AND cols.index_name = ind.index_name\\n            GROUP BY ind.index_name, ind.index_type\\n        \" - PARAMS = ('vario_examplelayout',); args=['vario_examplelayout']\n[2018-06-15 08:51:13.696 | DEBUG | django.db.backends.schema:124] ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT \"VARIO_EXA_UUID_8498C9C8_P\" PRIMARY KEY (\"UUID\"); (params ())\n[2018-06-15 08:51:13.775 | DEBUG | django.db.backends:111] (0.079) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT \"VARIO_EXA_UUID_8498C9C8_P\" PRIMARY KEY (\"UUID\")' - PARAMS = (); args=()\nTraceback (most recent call last):\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 85, in _execute\n    return self.cursor.execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/oracle/base.py\", line 500, in execute\n    return self.cursor.execute(query, self._param_generator(params))\ncx_Oracle.DatabaseError: ORA-02261: such unique or primary key already exists in the table\n\nThe above exception was the direct cause of the following exception:\n\nTraceback (most recent call last):\n  File \"./manage.py\", line 35, in <module>\n    execute_from_command_line(sys.argv)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/__init__.py\", line 371, in execute_from_command_line\n    utility.execute()\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/__init__.py\", line 365, in execute\n    self.fetch_command(subcommand).run_from_argv(self.argv)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/base.py\", line 288, in run_from_argv\n    self.execute(*args, **cmd_options)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/base.py\", line 335, in execute\n    output = self.handle(*args, **options)\n  File \"/var/www/forms/forms/common/management/commands/migrate.py\", line 54, in handle\n    super().handle(*args, **options)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/commands/migrate.py\", line 200, in handle\n    fake_initial=fake_initial,\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/executor.py\", line 117, in migrate\n    state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/executor.py\", line 147, in _migrate_all_forwards\n    state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/executor.py\", line 244, in apply_migration\n    state = migration.apply(state, schema_editor)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/migration.py\", line 122, in apply\n    operation.database_forwards(self.app_label, schema_editor, old_state, project_state)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/operations/fields.py\", line 216, in database_forwards\n    schema_editor.alter_field(from_model, from_field, to_field)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/oracle/schema.py\", line 59, in alter_field\n    super().alter_field(model, old_field, new_field, strict)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/base/schema.py\", line 525, in alter_field\n    old_db_params, new_db_params, strict)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/base/schema.py\", line 725, in _alter_field\n    \"columns\": self.quote_name(new_field.column),\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/base/schema.py\", line 133, in execute\n    cursor.execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 100, in execute\n    return super().execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/raven/contrib/django/client.py\", line 127, in execute\n    return real_execute(self, sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 68, in execute\n    return self._execute_with_wrappers(sql, params, many=False, executor=self._execute)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 77, in _execute_with_wrappers\n    return executor(sql, params, many, context)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 85, in _execute\n    return self.cursor.execute(sql, params)\n  File \"/var/www/forms/forms/forms/db/backends/utils.py\", line 16, in execute\n    return super().execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/raven/contrib/django/client.py\", line 127, in execute\n    return real_execute(self, sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 68, in execute\n    return self._execute_with_wrappers(sql, params, many=False, executor=self._execute)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 77, in _execute_with_wrappers\n    return executor(sql, params, many, context)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 85, in _execute\n    return self.cursor.execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/utils.py\", line 89, in __exit__\n    raise dj_exc_value.with_traceback(traceback) from exc_value\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 85, in _execute\n    return self.cursor.execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/oracle/base.py\", line 500, in execute\n    return self.cursor.execute(query, self._param_generator(params))\ndjango.db.utils.DatabaseError: ORA-02261: such unique or primary key already exists in the table\nNotice the two calls:\n[2018-06-15 08:51:11.437 | DEBUG | django.db.backends:111] (0.094) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT vario_exa_uuid_8498c9c8_u UNIQUE (\"UUID\")' - PARAMS = (); args=()\nand a bit below:\n[2018-06-15 08:51:13.775 | DEBUG | django.db.backends:111] (0.079) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT \"VARIO_EXA_UUID_8498C9C8_P\" PRIMARY KEY (\"UUID\")' - PARAMS = (); args=()\n...which raises the error\nThe only other operations before this on this field that I have in one of the previous migrations is to actually add this UUID field as a nullable, non-unique field, and then in a data migration to populate it with a unique uuids for all ExampleLayouts:\n# prepare to migrate to UUID PKs for ExampleLayout and LayoutField\n        migrations.AddField(\n            model_name='examplelayout',\n            name='uuid',\n            field=models.UUIDField(null=True, default=uuid.uuid4),\n        ),\nFor completeness, the initial models look like this:\nclass\nExampleLayout\n(\nmodels\n.\nModel\n):\nimage\n=\nmodels\n.\nOneToOneField\n(\nImage\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'example_layout'\n)\ndoc_type\n=\nmodels\n.\nForeignKey\n(\nDocumentType\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'layouts'\n)\nclass\nLayoutField\n(\nmodels\n.\nModel\n):\ncore_field_type\n=\nmodels\n.\nForeignKey\n(\nCoreFieldType\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'layout_fields'\n)\nlayout\n=\nmodels\n.\nForeignKey\n(\nExampleLayout\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'fields'\n)\nbounding_box\n=\nBoundingBoxCharField\n()\ntranscription\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n128\n)\nwhile their final \"target\" version that I am trying to migrate to is this:\nclass\nExampleLayout\n(\nmodels\n.\nModel\n):\nuuid\n=\nmodels\n.\nUUIDField\n(\ndefault\n=\nuuid\n.\nuuid4\n,\nprimary_key\n=\nTrue\n,\neditable\n=\nFalse\n)\nimage\n=\nmodels\n.\nOneToOneField\n(\nImage\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'example_layout'\n)\ndoc_type\n=\nmodels\n.\nForeignKey\n(\nDocumentType\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'layouts'\n)\nclass\nLayoutField\n(\nmodels\n.\nModel\n):\nuuid\n=\nmodels\n.\nUUIDField\n(\ndefault\n=\nuuid\n.\nuuid4\n,\nprimary_key\n=\nTrue\n,\neditable\n=\nFalse\n)\ncore_field_type\n=\nmodels\n.\nForeignKey\n(\nCoreFieldType\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'layout_fields'\n)\nlayout\n=\nmodels\n.\nForeignKey\n(\nExampleLayout\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'fields'\n)\nbounding_box\n=\nBoundingBoxCharField\n()\ntranscription\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n128\n)",
        "issue_id": 29496,
        "pr_number": 10058,
        "pr_title": "Fixed #29496 -- Fixed crash on Oracle when converting a non-unique field to primary key.",
        "pr_body": "Ticket [29496](https://code.djangoproject.com/ticket/29496).",
        "issue_closed_at": "2018-06-17T01:51:24",
        "base_commit": "e95008f2411d50929873f634c3e14ebac811fd28"
      },
      "summary": "### Summary:\nThis issue involves a database migration problem when attempting to convert a primary key from an auto-incrementing integer to a UUID in an Oracle database environment. The process functions correctly in PostgreSQL but encounters errors in Oracle 12. The specific error, ORA-02261, occurs due to an attempt to add a primary key constraint on a field that already has a unique constraint, which Oracle interprets as redundant since a primary key inherently requires uniqueness.\n\n1. **Problem description in general terms:**\n   The problem arises when altering a non-unique field to become a primary key in Oracle. The migration process inadvertently adds a UNIQUE constraint before attempting to set the field as the PRIMARY KEY, causing a conflict since Oracle interprets the subsequent primary key addition as duplicative.\n\n2. **Key symptoms and behaviors observed:**\n   The key symptom is the occurrence of a database error (ORA-02261) when executing the migration script. This error indicates that a unique or primary key constraint already exists on the column being altered. The error is caused by the sequential execution of SQL commands that first apply a UNIQUE constraint and then a PRIMARY KEY constraint to the same field.\n\n3. **Affected components or systems:**\n   The affected components are the Oracle database system and the Django migration scripts responsible for altering database schemas. Specifically, the issue is within the database schema editor logic of the Django framework when interfacing with Oracle.\n\n4. **Potential impact or severity:**\n   The severity of the issue is significant for deployments using Oracle databases, as it blocks schema migrations necessary for evolving the database structure. This could lead to deployment delays and inconsistencies between development and production environments if not addressed.\n\n5. **Any relevant technical details abstracted for broader understanding:**\n   The primary technical detail involves the behavior of the Django migration system when interacting with Oracle's constraint management. Oracle enforces stricter rules around constraints, where a field cannot have both a UNIQUE and a PRIMARY KEY constraint separately defined. The fix involves modifying the schema editor logic to recognize the redundancy and avoid adding a UNIQUE constraint if a PRIMARY KEY is intended.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Altering non-unique field to primary key fails on Oracle\n\nBody:\nI am trying to migrate a table from an auto-incrementing Integer PK to a UUID PK.\nI have custom-written migrations that add the new UUID field, add new foreign key fields in dependent tables, populate them, remove the old FKs, etc.\nOne of the final steps of the process is to alter the new uuid field in the table to be a primary_key:\nmigrations\n.\nAlterField\n(\nmodel_name\n=\n'examplelayout'\n,\nname\n=\n'uuid'\n,\nfield\n=\nmodels\n.\nUUIDField\n(\ndefault\n=\nuuid\n.\nuuid4\n,\nprimary_key\n=\nTrue\n,\neditable\n=\nFalse\n),\n),\nThe whole process works great on Postgres, but this specific step ends up in an error on Oracle 12, despite the fact that before this step there are no indexes in the DB on this field.\nquery = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT \"VARIO_EXA_UUID_8498C9C8_P\" PRIMARY KEY (\"UUID\")'\n...\ndjango.db.utils.DatabaseError: ORA-02261: such unique or primary key already exists in the table\nThe issue seems to be that Django tries to first add a UNIQUE constraint for the field, then a PRIMARY KEY on the same field. Here are all the SQL queries executed by this specific migration step:\n==================== STEP =========================  4  =====================\n\n\n[2018-06-15 08:51:11.141 | DEBUG | django.db.backends.schema:124] ALTER TABLE \"VARIO_EXAMPLELAYOUT\" MODIFY \"UUID\" DEFAULT '9cf3fe16f11d4fa09b62e337c50ae5f7'; (params [])\n[2018-06-15 08:51:11.212 | DEBUG | django.db.backends:111] (0.071) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" MODIFY \"UUID\" DEFAULT \\'9cf3fe16f11d4fa09b62e337c50ae5f7\\'' - PARAMS = (); args=[]\n[2018-06-15 08:51:11.212 | DEBUG | django.db.backends.schema:124] UPDATE \"VARIO_EXAMPLELAYOUT\" SET \"UUID\" = %s WHERE \"UUID\" IS NULL; (params ['347ac08714bd4c208ffd2f79e7932bb3'])\n[2018-06-15 08:51:11.269 | DEBUG | django.db.backends:111] (0.056) QUERY = 'UPDATE \"VARIO_EXAMPLELAYOUT\" SET \"UUID\" = :arg0 WHERE \"UUID\" IS NULL' - PARAMS = ('347ac08714bd4c208ffd2f79e7932bb3',); args=['347ac08714bd4c208ffd2f79e7932bb3']\n[2018-06-15 08:51:11.269 | DEBUG | django.db.backends.schema:124] ALTER TABLE \"VARIO_EXAMPLELAYOUT\" MODIFY \"UUID\" NOT NULL; (params [])\n[2018-06-15 08:51:11.343 | DEBUG | django.db.backends:111] (0.073) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" MODIFY \"UUID\" NOT NULL' - PARAMS = (); args=[]\n[2018-06-15 08:51:11.343 | DEBUG | django.db.backends.schema:124] ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT vario_exa_uuid_8498c9c8_u UNIQUE (\"UUID\"); (params ())\n[2018-06-15 08:51:11.437 | DEBUG | django.db.backends:111] (0.094) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT vario_exa_uuid_8498c9c8_u UNIQUE (\"UUID\")' - PARAMS = (); args=()\n[2018-06-15 08:51:11.792 | DEBUG | django.db.backends:111] (0.354) QUERY = \"\\n            SELECT\\n                user_constraints.constraint_name,\\n                LISTAGG(LOWER(cols.column_name), ',') WITHIN GROUP (ORDER BY cols.position),\\n                CASE user_constraints.constraint_type\\n                    WHEN 'P' THEN 1\\n                    ELSE 0\\n                END AS is_primary_key,\\n                CASE\\n                    WHEN user_constraints.constraint_type IN ('P', 'U') THEN 1\\n                    ELSE 0\\n                END AS is_unique,\\n                CASE user_constraints.constraint_type\\n                    WHEN 'C' THEN 1\\n                    ELSE 0\\n                END AS is_check_constraint\\n            FROM\\n                user_constraints\\n            LEFT OUTER JOIN\\n                user_cons_columns cols ON user_constraints.constraint_name = cols.constraint_name\\n            WHERE\\n                user_constraints.constraint_type = ANY('P', 'U', 'C')\\n                AND user_constraints.table_name = UPPER(:arg0)\\n            GROUP BY user_constraints.constraint_name, user_constraints.constraint_type\\n        \" - PARAMS = ('vario_examplelayout',); args=['vario_examplelayout']\n[2018-06-15 08:51:12.480 | DEBUG | django.db.backends:111] (0.688) QUERY = \"\\n            SELECT\\n                cons.constraint_name,\\n                LISTAGG(LOWER(cols.column_name), ',') WITHIN GROUP (ORDER BY cols.position),\\n                LOWER(rcols.table_name),\\n                LOWER(rcols.column_name)\\n            FROM\\n                user_constraints cons\\n            INNER JOIN\\n                user_cons_columns rcols ON rcols.constraint_name = cons.r_constraint_name AND rcols.position = 1\\n            LEFT OUTER JOIN\\n                user_cons_columns cols ON cons.constraint_name = cols.constraint_name\\n            WHERE\\n                cons.constraint_type = 'R' AND\\n                cons.table_name = UPPER(:arg0)\\n            GROUP BY cons.constraint_name, rcols.table_name, rcols.column_name\\n        \" - PARAMS = ('vario_examplelayout',); args=['vario_examplelayout']\n[2018-06-15 08:51:13.695 | DEBUG | django.db.backends:111] (1.214) QUERY = \"\\n            SELECT\\n                ind.index_name,\\n                LOWER(ind.index_type),\\n                LISTAGG(LOWER(cols.column_name), ',') WITHIN GROUP (ORDER BY cols.column_position),\\n                LISTAGG(cols.descend, ',') WITHIN GROUP (ORDER BY cols.column_position)\\n            FROM\\n                user_ind_columns cols, user_indexes ind\\n            WHERE\\n                cols.table_name = UPPER(:arg0) AND\\n                NOT EXISTS (\\n                    SELECT 1\\n                    FROM user_constraints cons\\n                    WHERE ind.index_name = cons.index_name\\n                ) AND cols.index_name = ind.index_name\\n            GROUP BY ind.index_name, ind.index_type\\n        \" - PARAMS = ('vario_examplelayout',); args=['vario_examplelayout']\n[2018-06-15 08:51:13.696 | DEBUG | django.db.backends.schema:124] ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT \"VARIO_EXA_UUID_8498C9C8_P\" PRIMARY KEY (\"UUID\"); (params ())\n[2018-06-15 08:51:13.775 | DEBUG | django.db.backends:111] (0.079) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT \"VARIO_EXA_UUID_8498C9C8_P\" PRIMARY KEY (\"UUID\")' - PARAMS = (); args=()\nTraceback (most recent call last):\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 85, in _execute\n    return self.cursor.execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/oracle/base.py\", line 500, in execute\n    return self.cursor.execute(query, self._param_generator(params))\ncx_Oracle.DatabaseError: ORA-02261: such unique or primary key already exists in the table\n\nThe above exception was the direct cause of the following exception:\n\nTraceback (most recent call last):\n  File \"./manage.py\", line 35, in <module>\n    execute_from_command_line(sys.argv)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/__init__.py\", line 371, in execute_from_command_line\n    utility.execute()\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/__init__.py\", line 365, in execute\n    self.fetch_command(subcommand).run_from_argv(self.argv)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/base.py\", line 288, in run_from_argv\n    self.execute(*args, **cmd_options)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/base.py\", line 335, in execute\n    output = self.handle(*args, **options)\n  File \"/var/www/forms/forms/common/management/commands/migrate.py\", line 54, in handle\n    super().handle(*args, **options)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/core/management/commands/migrate.py\", line 200, in handle\n    fake_initial=fake_initial,\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/executor.py\", line 117, in migrate\n    state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/executor.py\", line 147, in _migrate_all_forwards\n    state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/executor.py\", line 244, in apply_migration\n    state = migration.apply(state, schema_editor)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/migration.py\", line 122, in apply\n    operation.database_forwards(self.app_label, schema_editor, old_state, project_state)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/migrations/operations/fields.py\", line 216, in database_forwards\n    schema_editor.alter_field(from_model, from_field, to_field)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/oracle/schema.py\", line 59, in alter_field\n    super().alter_field(model, old_field, new_field, strict)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/base/schema.py\", line 525, in alter_field\n    old_db_params, new_db_params, strict)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/base/schema.py\", line 725, in _alter_field\n    \"columns\": self.quote_name(new_field.column),\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/base/schema.py\", line 133, in execute\n    cursor.execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 100, in execute\n    return super().execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/raven/contrib/django/client.py\", line 127, in execute\n    return real_execute(self, sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 68, in execute\n    return self._execute_with_wrappers(sql, params, many=False, executor=self._execute)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 77, in _execute_with_wrappers\n    return executor(sql, params, many, context)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 85, in _execute\n    return self.cursor.execute(sql, params)\n  File \"/var/www/forms/forms/forms/db/backends/utils.py\", line 16, in execute\n    return super().execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/raven/contrib/django/client.py\", line 127, in execute\n    return real_execute(self, sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 68, in execute\n    return self._execute_with_wrappers(sql, params, many=False, executor=self._execute)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 77, in _execute_with_wrappers\n    return executor(sql, params, many, context)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 85, in _execute\n    return self.cursor.execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/utils.py\", line 89, in __exit__\n    raise dj_exc_value.with_traceback(traceback) from exc_value\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/utils.py\", line 85, in _execute\n    return self.cursor.execute(sql, params)\n  File \"/var/www/venv/lib/python3.5/site-packages/django/db/backends/oracle/base.py\", line 500, in execute\n    return self.cursor.execute(query, self._param_generator(params))\ndjango.db.utils.DatabaseError: ORA-02261: such unique or primary key already exists in the table\nNotice the two calls:\n[2018-06-15 08:51:11.437 | DEBUG | django.db.backends:111] (0.094) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT vario_exa_uuid_8498c9c8_u UNIQUE (\"UUID\")' - PARAMS = (); args=()\nand a bit below:\n[2018-06-15 08:51:13.775 | DEBUG | django.db.backends:111] (0.079) QUERY = 'ALTER TABLE \"VARIO_EXAMPLELAYOUT\" ADD CONSTRAINT \"VARIO_EXA_UUID_8498C9C8_P\" PRIMARY KEY (\"UUID\")' - PARAMS = (); args=()\n...which raises the error\nThe only other operations before this on this field that I have in one of the previous migrations is to actually add this UUID field as a nullable, non-unique field, and then in a data migration to populate it with a unique uuids for all ExampleLayouts:\n# prepare to migrate to UUID PKs for ExampleLayout and LayoutField\n        migrations.AddField(\n            model_name='examplelayout',\n            name='uuid',\n            field=models.UUIDField(null=True, default=uuid.uuid4),\n        ),\nFor completeness, the initial models look like this:\nclass\nExampleLayout\n(\nmodels\n.\nModel\n):\nimage\n=\nmodels\n.\nOneToOneField\n(\nImage\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'example_layout'\n)\ndoc_type\n=\nmodels\n.\nForeignKey\n(\nDocumentType\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'layouts'\n)\nclass\nLayoutField\n(\nmodels\n.\nModel\n):\ncore_field_type\n=\nmodels\n.\nForeignKey\n(\nCoreFieldType\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'layout_fields'\n)\nlayout\n=\nmodels\n.\nForeignKey\n(\nExampleLayout\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'fields'\n)\nbounding_box\n=\nBoundingBoxCharField\n()\ntranscription\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n128\n)\nwhile their final \"target\" version that I am trying to migrate to is this:\nclass\nExampleLayout\n(\nmodels\n.\nModel\n):\nuuid\n=\nmodels\n.\nUUIDField\n(\ndefault\n=\nuuid\n.\nuuid4\n,\nprimary_key\n=\nTrue\n,\neditable\n=\nFalse\n)\nimage\n=\nmodels\n.\nOneToOneField\n(\nImage\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'example_layout'\n)\ndoc_type\n=\nmodels\n.\nForeignKey\n(\nDocumentType\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'layouts'\n)\nclass\nLayoutField\n(\nmodels\n.\nModel\n):\nuuid\n=\nmodels\n.\nUUIDField\n(\ndefault\n=\nuuid\n.\nuuid4\n,\nprimary_key\n=\nTrue\n,\neditable\n=\nFalse\n)\ncore_field_type\n=\nmodels\n.\nForeignKey\n(\nCoreFieldType\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'layout_fields'\n)\nlayout\n=\nmodels\n.\nForeignKey\n(\nExampleLayout\n,\non_delete\n=\nmodels\n.\nCASCADE\n,\nrelated_name\n=\n'fields'\n)\nbounding_box\n=\nBoundingBoxCharField\n()\ntranscription\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n128\n)\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/db/backends/base/schema.py\n  function: BaseDatabaseSchemaEditor._alter_field\n  function: BaseDatabaseSchemaEditor._alter_field\n  function: BaseDatabaseSchemaEditor._alter_field\n  function: BaseDatabaseSchemaEditor._field_indexes_sql\n\ndjango/db/backends/oracle/schema.py\n  function: DatabaseSchemaEditor._field_should_be_indexed\n"
    }
  ]
}