{
    "Selected_candidate": {
        "pr_number": 8629,
        "pr_title": "Fixed #28293 -- Fixed union(), intersection(), and difference() when combining with an EmptyQuerySet.",
        "pr_body": "https://code.djangoproject.com/ticket/28293",
        "issue_id": 28293,
        "issue_title": "QuerySet.union(QuerySet.none()) results in an empty queryset, should be the original queryset",
        "issue_body": "Tested on Django 1.11.2.\nAs\nQuerySet.union()\nuses the SQL\nUNION\noperator, I would expect \"SET1 UNION <EMPTY SET>\" to result in SET1. Currently it results in the empty set.\n>>> from django.contrib.auth.models import User\n>>> User.objects.count()\n100\n>>> list(User.objects.all().union(User.objects.none()))\n[]\nFrom\n​\nhttps://www.postgresql.org/docs/current/static/queries-union.html\nUNION effectively appends the result of query2 to the result of query1 ...\nQuerySet.difference()\nlooks to suffer from the same issue.",
        "issue_closed_at": "2017-06-13T01:16:29",
        "base_commit": "9dc83c356d363c090f3351c908cad6f823aeb7bf",
        "changes": [
            {
                "file": "django/db/models/query.py",
                "type": "function",
                "name": "_combinator_query",
                "class_name": "QuerySet",
                "code": "def _combinator_query(self, combinator, *other_qs, all=False):\n        # Clone the query to inherit the select list and everything\n        clone = self._clone()\n        # Clear limits and ordering so they can be reapplied\n        clone.query.clear_ordering(True)\n        clone.query.clear_limits()\n        clone.query.combined_queries = (self.query,) + tuple(qs.query for qs in other_qs)\n        clone.query.combinator = combinator\n        clone.query.combinator_all = all\n        return clone"
            },
            {
                "file": "django/db/models/sql/compiler.py",
                "type": "function",
                "name": "get_combinator_sql",
                "class_name": "SQLCompiler",
                "code": "def get_combinator_sql(self, combinator, all):\n        features = self.connection.features\n        compilers = [\n            query.get_compiler(self.using, self.connection)\n            for query in self.query.combined_queries\n        ]\n        if not features.supports_slicing_ordering_in_compound:\n            for query, compiler in zip(self.query.combined_queries, compilers):\n                if query.low_mark or query.high_mark:\n                    raise DatabaseError('LIMIT/OFFSET not allowed in subqueries of compound statements.')\n                if compiler.get_order_by():\n                    raise DatabaseError('ORDER BY not allowed in subqueries of compound statements.')\n        parts = (compiler.as_sql() for compiler in compilers)\n        combinator_sql = self.connection.ops.set_operators[combinator]\n        if all and combinator == 'union':\n            combinator_sql += ' ALL'\n        braces = '({})' if features.supports_slicing_ordering_in_compound else '{}'\n        sql_parts, args_parts = zip(*((braces.format(sql), args) for sql, args in parts))\n        result = [' {} '.format(combinator_sql).join(sql_parts)]\n        params = []\n        for part in args_parts:\n            params.extend(part)\n        return result, params"
            }
        ]
    },
    "Justification": "Candidate A is the most relevant bug report as it addresses a similar issue with `QuerySet`, particularly with its `union()` method, which directly relates to the unexpected behavior observed in the CURRENT bug when using `union()`. The structural similarities and the nature of the fix provide valuable insights that can guide debugging the current bug effectively."
}