{
  "id": "django__django-11179",
  "question": "delete() on instances of models without any dependencies doesn't clear PKs.\nDescription\n\t\nDeleting any model with no dependencies not updates the PK on the model. It should be set to None after .delete() call.\nSee Django.db.models.deletion:276-281. Should update the model line 280.\n",
  "answer": "{\"task_id\": \"3fbebea5-3100-4e18-ba35-f8318a6ca520\", \"workflow_run_id\": \"ca1600ca-bbaf-4ee7-855d-c59dd00ee8f0\", \"data\": {\"id\": \"ca1600ca-bbaf-4ee7-855d-c59dd00ee8f0\", \"workflow_id\": \"9a0a6efa-4d15-4876-b13f-4fb6a999caa2\", \"status\": \"succeeded\", \"outputs\": {\"final_patch\": [\"--- a/django/db/models/deletion.py\\n+++ b/django/db/models/deletion.py\\n@@ -277,6 +277,11 @@ class Collector:\\n                 # fast deletes\\n                 for qs in self.fast_deletes:\\n                     count = qs._raw_delete(using=self.using)\\n+                    # Set PK to None for instances with no dependencies\\n+                    if hasattr(qs, '_result_cache') and qs._result_cache:\\n+                        for obj in qs._result_cache:\\n+                            if obj.pk is not None:\\n+                                setattr(obj, obj._meta.pk.attname, None)\\n                     if count:\\n                         deleted_counter[qs.model._meta.label] += count\\n \\n@@ -278,6 +283,10 @@ class Collector:\\n                 # slow deletes\\n                 for model, instances in self.data.items():\\n                     query = sql.DeleteQuery(model)\\n+                    # Set PK to None for instances being deleted\\n+                    for instance in instances:\\n+                        if instance.pk is not None:\\n+                            setattr(instance, instance._meta.pk.attname, None)\\n                     pk_list = [obj.pk for obj in instances]\\n                     count = query.delete_batch(pk_list, self.using)\\n                     if count:\", \"--- a/django/db/models/deletion.py\\n+++ b/django/db/models/deletion.py\\n@@ -280,6 +280,14 @@ class Collector:\\n                     count = query.delete_batch(pk_list, self.using)\\n                     if count:\\n                         deleted_counter[model._meta.label] += count\\n+        \\n+        # Set PK to None for all deleted instances\\n+        for model, instances in self.data.items():\\n+            for instance in instances:\\n+                setattr(instance, instance._meta.pk.attname, None)\\n+        for qs in self.fast_deletes:\\n+            if hasattr(qs, '_result_cache') and qs._result_cache:\\n+                for obj in qs._result_cache:\\n+                    setattr(obj, obj._meta.pk.attname, None)\\n \\n         # update collected instances\\n         for instances_for_fieldvalues in self.field_updates.values():\", \"--- a/django/db/models/deletion.py\\n+++ b/django/db/models/deletion.py\\n@@ -276,12 +276,18 @@ class Collector:\\n         with transaction.atomic(using=self.using, savepoint=False):\\n             # send pre_delete signals\\n             for model, obj in self.instances_with_model():\\n                 if not model._meta.auto_created:\\n                     signals.pre_delete.send(\\n                         sender=model, instance=obj, using=self.using\\n                     )\\n \\n+            # Track instances to nullify PKs after deletion\\n+            instances_to_nullify = []\\n+            for model, instances in self.data.items():\\n+                instances_to_nullify.extend(instances)\\n+            for qs in self.fast_deletes:\\n+                if hasattr(qs, '_result_cache') and qs._result_cache:\\n+                    instances_to_nullify.extend(qs._result_cache)\\n+\\n             # fast deletes\\n             for qs in self.fast_deletes:\\n                 count = qs._raw_delete(using=self.using)\\n@@ -294,6 +300,10 @@ class Collector:\\n                 count = query.delete_batch(pk_list, self.using)\\n                 if count:\\n                     deleted_counter[model._meta.label] += count\\n+            \\n+            # Set PK to None for all deleted instances\\n+            for instance in instances_to_nullify:\\n+                setattr(instance, instance._meta.pk.attname, None)\\n \\n         # update collected instances\\n         for instances_for_fieldvalues in self.field_updates.values():\", \"--- a/django/db/models/deletion.py\\n+++ b/django/db/models/deletion.py\\n@@ -281,6 +281,12 @@ class Collector:\\n                 if count:\\n                     deleted_counter[model._meta.label] += count\\n \\n+        # Nullify primary keys of deleted instances\\n+        for model, instances in self.data.items():\\n+            pk_attname = model._meta.pk.attname\\n+            for instance in instances:\\n+                setattr(instance, pk_attname, None)\\n+\\n         # update collected instances\\n         for instances_for_fieldvalues in self.field_updates.values():\\n             for (field, value), instances in instances_for_fieldvalues.items():\", \"--- a/django/db/models/deletion.py\\n+++ b/django/db/models/deletion.py\\n@@ -276,6 +276,9 @@ class Collector:\\n         with transaction.atomic(using=self.using, savepoint=False):\\n             # send pre_delete signals\\n             for model, obj in self.instances_with_model():\\n+                # Store original PK for later nullification\\n+                if not hasattr(obj, '_original_pk'):\\n+                    obj._original_pk = obj.pk\\n                 if not model._meta.auto_created:\\n                     signals.pre_delete.send(\\n                         sender=model, instance=obj, using=self.using\\n@@ -281,6 +284,15 @@ class Collector:\\n                 if count:\\n                     deleted_counter[model._meta.label] += count\\n \\n+        # Set PK to None for deleted instances\\n+        for model, instances in self.data.items():\\n+            pk_attname = model._meta.pk.attname\\n+            for instance in instances:\\n+                if hasattr(instance, '_original_pk') and instance._original_pk is not None:\\n+                    setattr(instance, pk_attname, None)\\n+                    delattr(instance, '_original_pk')\\n+                elif getattr(instance, pk_attname) is not None:\\n+                    setattr(instance, pk_attname, None)\\n+\\n         # update collected instances\\n         for instances_for_fieldvalues in self.field_updates.values():\", \"diff\\n--- a/django/db/models/deletion.py\\n+++ b/django/db/models/deletion.py\\n@@ -278,6 +278,10 @@ class Collector:\\n             # slow deletes\\n             for model, instances in self.data.items():\\n                 query = sql.DeleteQuery(model)\\n                 pk_list = [obj.pk for obj in instances]\\n                 count = query.delete_batch(pk_list, self.using)\\n+                # Set PK to None for deleted instances\\n+                pk_attname = model._meta.pk.attname\\n+                for instance in instances:\\n+                    setattr(instance, pk_attname, None)\\n                 if count:\\n                     deleted_counter[model._meta.label] += count\\n\", \"diff\\n--- a/django/db/models/deletion.py\\n+++ b/django/db/models/deletion.py\\n@@ -281,6 +281,12 @@ class Collector:\\n                 if count:\\n                     deleted_counter[model._meta.label] += count\\n \\n+        # Set PK to None for all deleted instances\\n+        for model, instances in self.data.items():\\n+            pk_attname = model._meta.pk.attname\\n+            for instance in instances:\\n+                setattr(instance, pk_attname, None)\\n+\\n         # update collected instances\\n         for instances_for_fieldvalues in self.field_updates.values():\\n             for (field, value), instances in instances_for_fieldvalues.items():\\n\", \"diff\\n--- a/django/db/models/deletion.py\\n+++ b/django/db/models/deletion.py\\n@@ -281,6 +281,12 @@ class Collector:\\n                 if count:\\n                     deleted_counter[model._meta.label] += count\\n \\n+        # Set PK to None for all deleted instances\\n+        for model, instances in self.data.items():\\n+            pk_attname = model._meta.pk.attname\\n+            for instance in instances:\\n+                setattr(instance, pk_attname, None)\\n+\\n         # update collected instances\\n         for instances_for_fieldvalues in self.field_updates.values():\\n             for (field, value), instances in instances_for_fieldvalues.items():\\n\"]}, \"error\": \"\", \"elapsed_time\": 91.606683, \"total_tokens\": 35572, \"total_steps\": 30, \"created_at\": 1754648199, \"finished_at\": 1754648291}}"
}