#16152 closed defect (bug) (fixed)
category__in now shows posts from children categories too
Reported by: | linuxologos | Owned by: | |
---|---|---|---|
Milestone: | 3.1 | Priority: | normal |
Severity: | normal | Version: | 3.1 |
Component: | Query | Keywords: | has-patch commit |
Focuses: | Cc: |
Description
Until 3.0.4 category_in parameter of query_posts() does not show posts from any children of the categories given to it, as currently stated in the codex too. In 3.1-RC2 it does show posts from child-categories.
Let's say we have a category with some subcategories. Posts are assigned either to parent category or to children of the category (not both to parent and child). If we use
query_posts( array( 'category__in' => array($parent_category_id) ) )
in 3.0.4 only posts assigned to parent category are shown.
But in 3.1 posts from parent as well as subcategories are shown with the same code.
I'm not sure if it is a bug or just the way the parameter will work since 3.1, but people using this parameter that way will possibly see their sites working unexpectedly after upgrading to 3.1.
Attachments (4)
Change History (30)
#3
@
14 years ago
parse_tax_query()
calls WP_Tax_Query()
, where include_children
is true by default. Is it safe to use 'include_children' => false
for category__in
and category__not_in
?
#7
@
14 years ago
Wont' this break 'cat' queries, which should include children? 'cat' gets mapped to 'categoryin' which the patch changes to not include children.
#8
follow-up:
↓ 11
@
14 years ago
Perhaps the 'cat' block could set a flag to force inclusion of children for 'category__in'. This would mean that passing both cat and category__in would result in child inclusion for all categories. A small back compat break. Alternatively, go back to calling get_term_children() inside the 'cat' block.
#11
in reply to:
↑ 8
;
follow-up:
↓ 12
@
14 years ago
Replying to ryan:
Perhaps the 'cat' block could set a flag to force inclusion of children for 'category__in'. This would mean that passing both cat and category__in would result in child inclusion for all categories. A small back compat break. Alternatively, go back to calling get_term_children() inside the 'cat' block.
I'm inclined to the second option. Is there a reason why it was removed? Can't find the changeset.
#14
@
14 years ago
Note that parse_tax_query() is run twice. It'd be nice to avoid finding all children twice, especially for the second call which will already include the children.
#15
@
14 years ago
Actually, since the children are not put back into the 'cat' arg we won't have to look up children for the children on the second pass. We're still unnecessarily finding the children for the terms in 'cat' again, however. parse_tax_query() may need an extra arg indicating that it is being called a second time. The second call to parse_tax_query(), right before get_sql(), could pass this flag and cause parse_tax_query() to skip the 'cat' block.
#20
@
14 years ago
Can't this last changeset break plugins that rely on wp_query to parse arbitrary queries?
#21
follow-up:
↓ 22
@
14 years ago
The change prevents only 'cat' from being processed again. I don't see a need to double process that. The flag is cleared for subsequent query() calls made using the same object.
Multiple tax queries are still possible. I tested with requests such as:
$query = new WP_Query( array('tag_slug__and' => array('foo', 'bar', 'test',), 'tag__in' => array( 3 ) ) );
That creates two entries in the tax_query list. One of which is operator AND and the other IN. These two have a 'relationship' of AND. The resulting query is like:
SELECT SQL_CALC_FOUND_ROWS wp_trunk_posts.* FROM wp_trunk_posts INNER JOIN wp_trunk_term_relationships ON (wp_trunk_posts.ID = wp_trunk_term_relationships.object_id) WHERE 1=1 AND ( wp_trunk_term_relationships.term_taxonomy_id IN (12) AND wp_trunk_posts.ID IN ( SELECT object_id FROM wp_trunk_term_relationships WHERE term_taxonomy_id IN (12,13,14) GROUP BY object_id HAVING COUNT(object_id) = 3 ) ) AND wp_trunk_posts.post_type = 'post' AND (wp_trunk_posts.post_status = 'publish' OR wp_trunk_posts.post_status = 'private') GROUP BY wp_trunk_posts.ID ORDER BY wp_trunk_posts.post_date DESC LIMIT 0, 5
#22
in reply to:
↑ 21
@
14 years ago
Replying to ryan:
The change prevents only 'cat' from being processed again. I don't see a need to double process that. The flag is cleared for subsequent query() calls made using the same object.
I'll give it a quick whirl this week (and change my forked plugin if needed). But my point was, I was mainly worried of old time plugins (which are still in use) along the lines of Custom Query String, which worked fine to date in spite of being massively obsolete, and which calls $wp_query->parse_query() using arbitrary arguments to do its stuff.
There may be a connection with #16088.