#11104 closed Bug (wontfix)
HAVING filter screws with extra() SQL parameter ordering
Reported by: | miracle2k | Owned by: | |
---|---|---|---|
Component: | Database layer (models, ORM) | Version: | dev |
Severity: | Normal | Keywords: | QuerySet.extra |
Cc: | bas@…, shaunc@… | Triage Stage: | Accepted |
Has patch: | no | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
>>> qs = Model.objects.extra(where=['foo>%s'], params=[2]).annotate(count=Count('bar')).filter(bar=99) >>> qs.query.as_sql() ('SELECT `site_publication`.`id`, ..., FROM ... WHERE foo > %s GROUP BY ... HAVING bar > %s', (99, 2))
As you can see, the parameters (99 and 2) are in the wrong order. "foo", the first filter, should be evaluated against 2, and bar, the second one, against 99.
If "bar" is not an aggregate, it works, because apparently the filter would be placed in the WHERE clause *before* the "extra()" where.
Using rev. 10743.
Attachments (1)
Change History (14)
comment:1 by , 16 years ago
Triage Stage: | Unreviewed → Accepted |
---|
comment:2 by , 16 years ago
I think all filters on annotated queryset should end up in HAVING clause, not in WHERE
imagine you want to do something like:
SELECT * FROM blog group by location, rating having count(id) > 10 OR rating >1
right now (r11199) you can ony add HAVING clauses using if you filter using an aggregate. Does this make sense to you?
by , 15 years ago
Attachment: | django.db.models.sql.query.diff added |
---|
changing grouping generation from values to keys of extra selects
comment:4 by , 15 years ago
I think that I've found bug related to this ticket. When generating list for grouping values (not keys) are taken from extra selects.
--- django/db/models/sql/query.py (revision 11729) +++ django/db/models/sql/query.py (working copy) @@ -885,9 +885,9 @@ group_by = self.group_by or [] extra_selects = [] - for extra_select, extra_params in self.extra_select.itervalues(): - extra_selects.append(extra_select) - params.extend(extra_params) + for extra_select_key in self.extra_select.iterkeys(): + extra_selects.append(extra_select_key) + for col in group_by + self.related_select_cols + extra_selects: if isinstance(col, (list, tuple)): result.append('%s.%s' % (qn(col[0]), qn(col[1])))
comment:5 by , 15 years ago
sorry for my previous post and attachment - it's related to #11916 which I've reopened.
comment:6 by , 15 years ago
Cc: | added |
---|
comment:7 by , 15 years ago
Cc: | added |
---|
comment:8 by , 14 years ago
Severity: | → Normal |
---|---|
Type: | → Bug |
comment:11 by , 12 years ago
Component: | ORM aggregation → Database layer (models, ORM) |
---|
comment:12 by , 9 years ago
Resolution: | → wontfix |
---|---|
Status: | new → closed |
We are no longer fixing bugs with QuerySet.extra()
per discussion on django-developers.
comment:13 by , 9 years ago
Keywords: | QuerySet.extra added |
---|
A related use case, reported in #11117:
the resulting sql query is:
The placeholder values '%H' and '22:00' are interchanged, which is obviously a result of using the GROUP BY here on a user-defined variable with placeholder (--> 'date')