Wordpress搜索结果按优先级显示(按标题显示第一个帖子)

时间:2014-08-29 07:05:12

标签: php mysql wordpress

  

我为自定义搜索实施了一些搜索过滤器。所以现在我有   按标题和自定义字段获取帖子的搜索功能。但是   返回的结果显示随机。

     

我希望首先按标题显示搜索结果,然后按自定义显示搜索结果   领域。 Search result

     

有办法吗?

     

搜索效果很好,只需按优先级显示即可。这是   我的搜索代码。

add_filter('posts_orderby','my_sort_custom',10,2);
        function my_sort_custom( $orderby, $query ){
            global $wpdb;

                if(is_search()){

                    $orderby =  $wpdb->prefix."posts.post_type DESC, {$wpdb->prefix}posts.ID ASC";
            }
            return  $orderby;
        }

 function __search_by_title_only( $search, &$wp_query )
{
    global $wpdb;

    if ( empty( $search ) )
        return $search; // skip processing - no search term in query

    $q = $wp_query->query_vars;    
    $n = ! empty( $q['exact'] ) ? '' : '%';

    $search =
    $searchand = '';

    foreach ( (array) $q['search_terms'] as $term ) {
        $term = esc_sql( like_escape( $term ) );
        $search .= "{$searchand}($wpdb->posts.post_title LIKE '{$n}{$term}{$n}') ";
        //$searchand = ' AND ';
    }

    if ( ! empty( $search ) ) {
        $search = " AND ({$search}) ";
        if ( ! is_user_logged_in() )
            $search .= " AND ($wpdb->posts.post_password = '') ";
    }

    return $search;
}
add_filter( 'posts_search', '__search_by_title_only', 1, 2 );




 function posts_join_post_meta( $join, $query ){

    global $wpdb;

    if( is_search()){

        $join .= "
        INNER JOIN
          {$wpdb->postmeta} ON {$wpdb->posts}.ID = {$wpdb->postmeta}.post_id";

    }

    return $join;

}
add_filter( 'posts_join', 'posts_join_post_meta', 2, 2 );




function recipe_search_where( $where, $query ){

    global $wpdb;
    if(is_search() ){
        $where .= " OR (
        {$wpdb->postmeta}.meta_key = '_recipe_incredients' AND {$wpdb->postmeta}.meta_value LIKE ('%".$wpdb->escape( get_query_var('s') )."%') ) ";
    }
    return $where;
}
add_filter( 'posts_where', 'recipe_search_where', 10, 2 );

1 个答案:

答案 0 :(得分:1)

您的帖子仅显示随机,因为您还要在此行ID中按{$wpdb->prefix}posts.ID ASC对其进行排序,尝试删除此内容并仅按帖子类型对其进行排序。

如果上述方法不起作用,只需编写自己的纯SQL查询并执行它。 同样重要的注意事项:$wpdb->escape()函数已被弃用,请尝试使用$wpdb->prepare()以防止SQL注入。

仅限示例:

$wpdb->query($wpdb->prepare("
     SELECT $wpdb->posts
     INNER JOIN $wpdb->postmeta ON $wpdb->posts.ID = $wpdb->postmeta.post_id
     WHERE 1 = 1
     AND $wpdb->postmeta.meta_key = %s
     AND $wpdb->postmeta.meta_value LIKE %s
     ORDER BY $wpdb->posts.post_type DESC
     ",
    '_recipe_incredients', '%'.get_query_var('s').'%')
);

有关详细信息,请参阅here