从2个类别和不同的分类中获取帖子。

时间:2013-06-25 08:52:17

标签: wordpress categories posts

我有一个自定义帖子(它叫做“ait-dir-items”)和2个类别。 在类别存档页面上,我需要获得属于2个类别的帖子。

从2个类别中获取帖子

Codition。 category1 =“ait-dir-item-category”上的“食物”(食物ID为6) 和 category2 =“ait-dir-item-category”上的“cate”(食物ID为39) 和 post_type = “AIT-DIR-项”

我一直在尝试3种方法来解决这个问题。 他们都没有运作良好。请告诉我如何解决它。

第一路

query_posts("cat=6, 39&showposts=5&post_type=ait-dir-item");
//query_posts( array( post_type=>'ait-dir-item', 'category__and' => array(6,39),         'posts_per_page' => 12, 'orderby' => 'title', 'order' => 'DESC' ) );

while(have_posts()) : the_post();

echo $title = get_the_title();
echo $content = get_the_content();
endwhile;

当我输入“cat = 6,39”或“'category__and'=>数组(6,39)”时,未找到任何结果。

第二路

global $post;

$tmp_post = $post;

$args = array(
'posts_per_page' => 5,
'post_type' => 'ait-dir-item',
'category__and' => array(6, 39) // where 1, 2 is cat id
/*'tax_query' => array(
array(
'taxonomy' => 'ait-dir-item-special',
'field' => 'id',
'terms' => 39 // taxonomy id
)
)*/
);
$myposts = get_posts( $args );
foreach( $myposts as $post ) :

$feat_image = wp_get_attachment_url( get_post_thumbnail_id($post->ID) );
$thumb = wp_get_attachment_image_src( get_post_thumbnail_id($post->ID), 'thumbnail_size' );
$url = $thumb['0'];
?>

<li class="display_special_items"><img src="<? echo $url; ?>"/>"><?php the_title(); ?>
<?php endforeach; ?>
<?php $post = $tmp_post; ?>
<li class="clear">

第三种方式:关系和AND


$custom_terms = get_terms('ait-dir-item-special');
$other_custom_terms = get_terms('ait-dir-item-category');

foreach ($custom_terms as $custom_term) {
foreach ($other_custom_terms as $other_custom_term) {
wp_reset_query();
$args = array('post_type' => 'ait-dir-item',
'tax_query' => array(
'relation' => 'AND',
array(
'taxonomy' => 'ait-dir-item-category',
'field' => 'id',
'terms' => 6
),
array(
'taxonomy' => 'ait-dir-item-special',
'field' => 'id',
'terms' => 39
),
),
);

$loop = new WP_Query($args);
if($loop->have_posts()) {
echo '<h1 style="margin-top:10px;">'.$custom_term->name.'</h1>';

while($loop->have_posts()) : $loop->the_post();
echo '<h2>'.get_the_title().'</h2>';
endwhile;
}
}
}

` 我想我对这些代码几乎没有问题。它显示但重复和所有项目帖子。我该如何解决?

谢谢,

2 个答案:

答案 0 :(得分:0)

您的语法不正确。请关注Wordpress的'query_posts'参考指南!

请在此处阅读http://codex.wordpress.org/Function_Reference/query_posts

你需要使用它:

query_posts( array( 'category__and' => array(1,3), 'posts_per_page' => 2, 'orderby' => 'title', 'order' => 'DESC' ) );

您可以根据自己的需要使用其他类别的过滤器!

答案 1 :(得分:0)

我有类似的情况,找不到答案:

  • 检索属于custom_taxonomy1且属于custom_taxonomy2的同一custom_type的所有帖子。

示例:我需要属于某个政党(custom_taxonomy2)的SectorA(custom_taxonomy1)的所有提案:

我最终使用了以下适用于我的案例的查询,您可能会得到一个想法并为您拍摄:

SELECT 
wposts.ID, 
wposts.post_title, 
wposts.post_type, 
wposts.post_status,

termRels.object_id termObjectId, 
termRels.term_taxonomy_id termTaxId, 
terms.name partido

FROM $wpdb->posts wposts

INNER JOIN $wpdb->terms terms  
ON terms.term_id = $p 

INNER JOIN $wpdb->terms termsSector  
ON termsSector.term_id = $sector   

INNER JOIN $wpdb->term_taxonomy termTax 
ON termTax.term_id = terms.term_id 

INNER JOIN $wpdb->term_taxonomy termTax2  
ON termTax2.term_id = termsSector.term_id  

INNER JOIN $wpdb->term_relationships termRels  
ON termRels.term_taxonomy_id = termTax.term_taxonomy_id  

INNER JOIN $wpdb->term_relationships termRelsSector   
ON termRelsSector.term_taxonomy_id = termTax2.term_taxonomy_id  

WHERE wposts.post_type = 'likan_planes'

AND wposts.post_title != 'Auto Draft' 
AND wposts.post_status = 'publish' 

AND wposts.ID = termRels.object_id 
AND termRels.object_id = termRelsSector.object_id 

ORDER BY wposts.post_title ASC