繁体   English   中英

WordPress-按分类搜索帖子

[英]WordPress - Search posts by Taxonomy

我的自定义WP搜索查询

$args = array(
        'post_type' => 'post',
        'taxonomy'  => 'location',
        'field' => 'name',
        'posts_per_page' => 10,
        'term' => $keyword,
    );
$wp_query = new WP_Query($args);

我有2个帖子,位置是伦敦和伦敦的牛津。现在,当我搜索伦敦时,它仅显示1个帖子**(第一个)**。同样,当我搜索牛津时,它也没有找到结果。

当我搜索牛津伦敦时,它的工作正常。

Befor WP_Query Run编写此代码

function advance_search_where($where){
    global $wpdb;
    if (is_search())
        $where .= "OR (t.name LIKE '%".get_search_query()."%' AND {$wpdb->posts}.post_status = 'publish')";
    return $where;
}

function advance_search_join($join){
    global $wpdb;
    if (is_search())
        $join .= "LEFT JOIN {$wpdb->term_relationships} tr ON {$wpdb->posts}.ID = tr.object_id INNER JOIN {$wpdb->term_taxonomy} tt ON tt.term_taxonomy_id=tr.term_taxonomy_id INNER JOIN {$wpdb->terms} t ON t.term_id = tt.term_id";
    return $join;
}

function advance_search_groupby($groupby){
    global $wpdb;

    // we need to group on post ID
    $groupby_id = "{$wpdb->posts}.ID";
    if(!is_search() || strpos($groupby, $groupby_id) !== false) return $groupby;

    // groupby was empty, use ours
    if(!strlen(trim($groupby))) return $groupby_id;

    // wasn't empty, append ours
    return $groupby.", ".$groupby_id;
}

add_filter('posts_where','advance_search_where');
add_filter('posts_join', 'advance_search_join');
add_filter('posts_groupby', 'advance_search_groupby');

现在像这样运行您的WP_Query

$args = array(
        'post_type' => 'post',
        'posts_per_page' => 10,
        's' => $keyword,
    );
$wp_query = new WP_Query($args);

在获得所有结果之后,如果您不删除该结果,则只需要删除上面的过滤器coz即可,它将应用于该页面的其他wp_query中。

remove_filter('posts_where','advance_search_where');
remove_filter('posts_join', 'advance_search_join');
remove_filter('posts_groupby', 'advance_search_groupby');

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM