如果你直接通过SQL获取的话,那么这篇文章可能意义不大,毕竟SQL已经是最直接的了。
如果你不是的话,希望达到这个效果,下面的代码可以帮你解决:
/** * Search SQL filter for matching against post title only. * * @link http://wordpress.stackexchange.com/a/11826/1685 * * @param string $search * @param WP_Query $wp_query */ function wpse_11826_search_by_title( $search, $wp_query ) { if ( ! empty( $search ) && ! empty( $wp_query->query_vars['search_terms'] ) ) { global $wpdb; $q = $wp_query->query_vars; $n = ! empty( $q['exact'] ) ? '' : '%'; $search = array(); foreach ( ( array ) $q['search_terms'] as $term ) $search[] = $wpdb->prepare( "$wpdb->posts.post_title LIKE %s", $n . $wpdb->esc_like( $term ) . $n ); if ( ! is_user_logged_in() ) $search[] = "$wpdb->posts.post_password = ''"; $search = ' AND ' . implode( ' AND ', $search ); } return $search; } add_filter( 'posts_search', 'wpse_11826_search_by_title', 10, 2 );
代码中已经包含了出处,如果感兴趣的可以去看看,简单的说这个代码的功能就是替换主查询中的查询参数达到想要的目的,但是使用的过滤器我倒是第一次注意到,之前都是pre_get_post,针对搜索的过滤器是第一关注。