Wordpress - 某些搜索结果未显示



我们有一个网站已经接管了。有一个名为"项目"的自定义帖子类型。

如果我们在frontend上使用术语"学习"进行搜索,结果不会显示标题为"Caulfield Grammar School,总体规划和学习项目"的项目,即使标题中有"学习"一词。然而,如果我们使用术语"Caulfield"进行搜索,它就会出现在搜索结果中。

该网站正在运行Relevanssi,即使禁用了它,搜索结果也不会显示。任何想法将不胜感激。

提前谢谢。

这有点有效,但还有其他帖子类型需要显示结果,所以我将代码更改为:

add_filter( 'pre_get_posts', 'mjt_project_search' );
function mjt_project_search( $query ) {
    if ( $query->is_search ) {
    $query->set( 'post_type', array( 'projects', 'news', 'award', 'person', 'location', 'page') );
    $query->set( 'post_status', array( 'publish') );
    }
    return $query;
}

这已经奏效了,但它现在没有显示"考菲尔德文法学校,总体规划和学习项目"。

请在函数中尝试以下代码.php

add_filter( 'pre_get_posts', 'mjt_project_search' );
function mjt_project_search( $query ) {
    if ( $query->is_search ) {
    $query->set( 'post_type', array( 'projects') );
    $query->set( 'post_status', array( 'publish') );
    }
    return $query;
}
/*custom texonomy */
function mjt_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 mjt_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 mjt_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','mjt_search_where');
add_filter('posts_join', 'mjt_search_join');
add_filter('posts_groupby', 'mjt_search_groupby');

最新更新