{
  "Selected_candidate": {
    "pr_number": 9491,
    "pr_title": "Fixed #28958 -- Fixed admin changelist crash when using a query expression in the page's ordering.",
    "pr_body": "https://code.djangoproject.com/ticket/28958",
    "issue_id": 28958,
    "issue_title": "Admin changelist crashes when using query expression in the model's Meta.ordering or ModelAdmin.ordering",
    "issue_body": "Using the newly introduced query-expression ordering feature in either the model's Meta.ordering or in its ModelAdmin causes errors.\nSteps to reproduce:\nFirst variant - using the model's Meta.ordering option -\n//models.py\nclass Game(models.Model):\n    score = models.IntegerField(null=True)\n\n     class Meta:\n         ordering = [F(\"score\").desc(nulls_last=True)]\n...\n// admin.py\nadmin.site.register(Game)\nAccessing the admin site will now give an\nAttributeError: 'OrderBy' object has no attribute 'startswith'\nVariant 2 - Using the ModelAdmin ordering attribute:\n//admin.py\nclass GameAdmin(models.ModelAdmin):\n    ordering = [F(\"score\").desc(nulls_last=True)]\nrunserver\nfails with error:\nTypeError: argument of type 'OrderBy' is not iterable",
    "issue_closed_at": "2017-12-27T11:38:54",
    "base_commit": "ef6c680f60a8e2ab45c936ec91f856fb3d7dc651",
    "changes": [
      {
        "file": "django/contrib/admin/views/main.py",
        "type": "line",
        "name": "line 15",
        "code": ")\nfrom django.core.paginator import InvalidPage\nfrom django.db import models\nfrom django.urls import reverse\nfrom django.utils.http import urlencode\nfrom django.utils.translation import gettext"
      },
      {
        "file": "django/contrib/admin/views/main.py",
        "type": "function",
        "name": "get_ordering_field_columns",
        "class_name": "ChangeList",
        "code": "def get_ordering_field_columns(self):\n        \"\"\"\n        Return an OrderedDict of ordering field column numbers and asc/desc.\n        \"\"\"\n        # We must cope with more than one column having the same underlying sort\n        # field, so we base things on column numbers.\n        ordering = self._get_default_ordering()\n        ordering_fields = OrderedDict()\n        if ORDER_VAR not in self.params:\n            # for ordering specified on ModelAdmin or model Meta, we don't know\n            # the right column numbers absolutely, because there might be more\n            # than one column associated with that ordering, so we guess.\n            for field in ordering:\n                if field.startswith('-'):\n                    field = field[1:]\n                    order_type = 'desc'\n                else:\n                    order_type = 'asc'\n                for index, attr in enumerate(self.list_display):\n                    if self.get_ordering_field(attr) == field:\n                        ordering_fields[index] = order_type\n                        break\n        else:\n            for p in self.params[ORDER_VAR].split('.'):\n                none, pfx, idx = p.rpartition('-')\n                try:\n                    idx = int(idx)\n                except ValueError:\n                    continue  # skip it\n                ordering_fields[idx] = 'desc' if pfx == '-' else 'asc'\n        return ordering_fields"
      }
    ]
  },
  "Justification": "Candidate D is the most relevant because it directly deals with a similar issue involving ordering within a model's Meta class, which is a key aspect of the CURRENT bug. Both bugs involve errors related to ordering expressions, and Candidate D's fix addresses the crashes caused by using query expressions in the Meta.ordering. This shared focus on ordering behavior makes it particularly valuable for debugging the CURRENT bug where the intended order (DESC) is not achieved, providing insight into potential issues with ordering expressions in an inheritance structure.",
  "instance_id": "django__django-12470",
  "repo": "django/django",
  "created_at": "2020-02-19T04:48:55Z",
  "problem_statement": "Inherited model doesn't correctly order by \"-pk\" when specified on Parent.Meta.ordering\nDescription\n\t\nGiven the following model definition:\nfrom django.db import models\nclass Parent(models.Model):\n\tclass Meta:\n\t\tordering = [\"-pk\"]\nclass Child(Parent):\n\tpass\nQuerying the Child class results in the following:\n>>> print(Child.objects.all().query)\nSELECT \"myapp_parent\".\"id\", \"myapp_child\".\"parent_ptr_id\" FROM \"myapp_child\" INNER JOIN \"myapp_parent\" ON (\"myapp_child\".\"parent_ptr_id\" = \"myapp_parent\".\"id\") ORDER BY \"myapp_parent\".\"id\" ASC\nThe query is ordered ASC but I expect the order to be DESC.\n",
  "patch": "diff --git a/django/db/models/sql/compiler.py b/django/db/models/sql/compiler.py\n--- a/django/db/models/sql/compiler.py\n+++ b/django/db/models/sql/compiler.py\n@@ -709,9 +709,9 @@ def find_ordering_name(self, name, opts, alias=None, default_order='ASC',\n         field, targets, alias, joins, path, opts, transform_function = self._setup_joins(pieces, opts, alias)\n \n         # If we get to this point and the field is a relation to another model,\n-        # append the default ordering for that model unless the attribute name\n-        # of the field is specified.\n-        if field.is_relation and opts.ordering and getattr(field, 'attname', None) != name:\n+        # append the default ordering for that model unless it is the pk\n+        # shortcut or the attribute name of the field that is specified.\n+        if field.is_relation and opts.ordering and getattr(field, 'attname', None) != name and name != 'pk':\n             # Firstly, avoid infinite loops.\n             already_seen = already_seen or set()\n             join_tuple = tuple(getattr(self.query.alias_map[j], 'join_cols', None) for j in joins)\n"
}