как ограничить поиск только заголовками записей?

12 мар. 2011 г., 16:06:33
Просмотры: 31K
Голосов: 29

Есть ли способ ограничить поиск только заголовками записей? Я знаю, что могу изменить core файл query.php, но должен быть способ сделать это с помощью хуков, верно?

Заранее спасибо!

0
Все ответы на вопрос 1
8
39

Вот фильтр, который поможет решить задачу. Добавьте его в файл functions.php вашей темы или в плагин.

/**
 * Фильтр SQL для поиска только по заголовкам записей.
 *
 * @link    http://wordpress.stackexchange.com/a/11826/1685
 *
 * @param   string      $search    Текущий SQL-запрос поиска
 * @param   WP_Query    $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;
}

// Добавляем фильтр к хуку posts_search
add_filter( 'posts_search', 'wpse_11826_search_by_title', 10, 2 );

Большая часть кода просто скопирована из класса WP_Query, за исключением удалённых условий post_content LIKE.

ОБНОВЛЕНИЕ: Удалена устаревшая функция like_escape() начиная с версии 4.0

12 мар. 2011 г. 16:51:08
Комментарии

отлично работает, я знал, что для этого есть фильтр, но нигде не мог найти его в кодексе, большое спасибо!

Javier Villanueva Javier Villanueva
12 мар. 2011 г. 18:19:23

@TheDeadMedic Я только что попробовал это на своем блоге, и этот конкретный запрос теперь вообще не возвращает результатов, с этим кодом или без него. Есть идеи?

Ashfame Ashfame
4 авг. 2011 г. 02:37:00

Теперь все работает как обычно без кода, но сам код у меня не сработал. Он показывал те же результаты :/

Ashfame Ashfame
4 авг. 2011 г. 10:32:42

@Ashfame Я пересмотрел свой ответ.

TheDeadMedic TheDeadMedic
4 авг. 2011 г. 15:44:44

Спасибо, это работает хорошо, если убрать {$n} рядом с {$term}, это делает поиск точным. Но есть проблема — он не ищет термины с пробелом, например "apple juice". Однако он находит просто apple.

User User
16 дек. 2011 г. 14:12:03

Да, если убрать {$n}, вы удаляете подстановку строки с wildcard. Оставьте код как есть и используйте URL-параметр exact=1, чтобы управлять, будет ли поиск приблизительным или точным.

TheDeadMedic TheDeadMedic
16 дек. 2011 г. 19:58:17

Сообщение PHP: Фатальная ошибка PHP: Вызов неопределенного метода wpdb::esc_like() --- Если у вас старая версия WordPress, это новая функция, появившаяся в WP 4.0

Jay Brunet Jay Brunet
10 нояб. 2015 г. 01:14:13

Можно ли использовать регулярные выражения вместо LIKE? Мой шаблон заголовка немного сложнее... Полагаю, это другой вопрос, но буду благодарен за любые подсказки. Спасибо

Drewdavid Drewdavid
23 нояб. 2019 г. 08:12:28
Показать остальные 3 комментариев