我为自定义搜索实施了一些搜索过滤器。所以现在我有 按标题和自定义字段获取帖子的搜索功能。但是 返回的结果显示随机。
我希望首先按标题显示搜索结果,然后按自定义显示搜索结果 领域。 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 );
答案 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。