{
  "Selected_candidate": {
    "pr_number": 13323,
    "pr_title": "Fixed #31902 -- Fixed crash of ExclusionConstraint on expressions with params.",
    "pr_body": "[Ticket 31902](https://code.djangoproject.com/ticket/31902)",
    "issue_id": 31902,
    "issue_title": "ExclusionConstraint crashes on expression with params.",
    "issue_body": "When expression for ExclusionConstraint is complex with some parameters Django fails to generate SQL because of wrong params substitution.\nExclusionConstraint(\n    name='field_left',\n    expressions=[(Left('field', 4), RangeOperators.EQUAL)],\n)",
    "issue_closed_at": "2020-08-19T00:34:22",
    "base_commit": "e2e34f4de3b90f3820ee11d49cc369ef573bc2ef",
    "changes": [
      {
        "file": "django/contrib/postgres/constraints.py",
        "type": "function",
        "name": "__init__",
        "class_name": "ExclusionConstraint",
        "code": "def __init__(\n        self, *, name, expressions, index_type=None, condition=None,\n        deferrable=None, include=None, opclasses=(),\n    ):\n        if index_type and index_type.lower() not in {'gist', 'spgist'}:\n            raise ValueError(\n                'Exclusion constraints only support GiST or SP-GiST indexes.'\n            )\n        if not expressions:\n            raise ValueError(\n                'At least one expression is required to define an exclusion '\n                'constraint.'\n            )\n        if not all(\n            isinstance(expr, (list, tuple)) and len(expr) == 2\n            for expr in expressions\n        ):\n            raise ValueError('The expressions must be a list of 2-tuples.')\n        if not isinstance(condition, (type(None), Q)):\n            raise ValueError(\n                'ExclusionConstraint.condition must be a Q instance.'\n            )\n        if condition and deferrable:\n            raise ValueError(\n                'ExclusionConstraint with conditions cannot be deferred.'\n            )\n        if not isinstance(deferrable, (type(None), Deferrable)):\n            raise ValueError(\n                'ExclusionConstraint.deferrable must be a Deferrable instance.'\n            )\n        if not isinstance(include, (type(None), list, tuple)):\n            raise ValueError(\n                'ExclusionConstraint.include must be a list or tuple.'\n            )\n        if include and index_type and index_type.lower() != 'gist':\n            raise ValueError(\n                'Covering exclusion constraints only support GiST indexes.'\n            )\n        if not isinstance(opclasses, (list, tuple)):\n            raise ValueError(\n                'ExclusionConstraint.opclasses must be a list or tuple.'\n            )\n        if opclasses and len(expressions) != len(opclasses):\n            raise ValueError(\n                'ExclusionConstraint.expressions and '\n                'ExclusionConstraint.opclasses must have the same number of '\n                'elements.'\n            )\n        self.expressions = expressions\n        self.index_type = index_type or 'GIST'\n        self.condition = condition\n        self.deferrable = deferrable\n        self.include = tuple(include) if include else ()\n        self.opclasses = opclasses\n        super().__init__(name=name)"
      },
      {
        "file": "django/contrib/postgres/constraints.py",
        "type": "function",
        "name": "_get_condition_sql",
        "class_name": "ExclusionConstraint",
        "code": "def _get_condition_sql(self, compiler, schema_editor, query):\n        if self.condition is None:\n            return None\n        where = query.build_where(self.condition)\n        sql, params = where.as_sql(compiler, schema_editor.connection)\n        return sql % tuple(schema_editor.quote_value(p) for p in params)"
      }
    ]
  },
  "Justification": "Candidate C is the most relevant as it deals with expressions in Django, directly similar to the issue with `ExpressionWrapper(~Q(pk__in=[]))` crashing due to complex parameters. Both bugs involve generating SQL from expressions with underlying problems in parameter substitution. Moreover, the fix focused on addressing crashes related to parameterized expressions, which aligns closely with the current issue's symptoms and operational context, making it invaluable for debugging effectively.",
  "instance_id": "django__django-15213",
  "repo": "django/django",
  "created_at": "2021-12-19T10:48:23Z",
  "problem_statement": "ExpressionWrapper for ~Q(pk__in=[]) crashes.\nDescription\n\t \n\t\t(last modified by Stefan Brand)\n\t \nProblem Description\nI'm reducing some Q objects (similar to what is described in ticket:32554. Everything is fine for the case where the result is ExpressionWrapper(Q(pk__in=[])). However, when I reduce to ExpressionWrapper(~Q(pk__in=[])) the query breaks.\nSymptoms\nWorking for ExpressionWrapper(Q(pk__in=[]))\nprint(queryset.annotate(foo=ExpressionWrapper(Q(pk__in=[]), output_field=BooleanField())).values(\"foo\").query)\nSELECT 0 AS \"foo\" FROM \"table\"\nNot working for ExpressionWrapper(~Q(pk__in=[]))\nprint(queryset.annotate(foo=ExpressionWrapper(~Q(pk__in=[]), output_field=BooleanField())).values(\"foo\").query)\nSELECT AS \"foo\" FROM \"table\"\n",
  "patch": "diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py\n--- a/django/db/models/fields/__init__.py\n+++ b/django/db/models/fields/__init__.py\n@@ -994,6 +994,15 @@ def formfield(self, **kwargs):\n             defaults = {'form_class': form_class, 'required': False}\n         return super().formfield(**{**defaults, **kwargs})\n \n+    def select_format(self, compiler, sql, params):\n+        sql, params = super().select_format(compiler, sql, params)\n+        # Filters that match everything are handled as empty strings in the\n+        # WHERE clause, but in SELECT or GROUP BY list they must use a\n+        # predicate that's always True.\n+        if sql == '':\n+            sql = '1'\n+        return sql, params\n+\n \n class CharField(Field):\n     description = _(\"String (up to %(max_length)s)\")\n"
}