Верх страницы
Обложка к записи Повышение производительности запросов в WordPress путем удаления post__not_in
Время для прочтения: 0 мин. 33 сек.

Повышение производительности запросов в WordPress путем удаления post__not_in

Используя post__not_in в запросах, вы делаете работу внутреннего кеша практически бесполезной, особенно, когда список исключений является большим, это очень замедляет сам запрос и, как следствие, работу сайта в целом.

Вместо такого кода, например:

$array_of_post_ids_to_skip = array(
    1,
    7,
    29,
);

$limit = 16;

$other_posts_in_tag = get_posts( array(
    'tag_id'           => $tag_id,
    'posts_per_page'   => $limit,
    'post__not_in'     => $array_of_post_ids_to_skip,
    'suppress_filters' => false,
));
 
foreach ( $other_posts_in_tag as $post ){
    // здесь сама логика;
}

Можно сделать такой хак — взять постов больше на размер массива $array_of_post_ids_to_skip и потом уже в цикле на PHP отбросить исключаемые посты:

$array_of_post_ids_to_skip = array(
    1,
    7,
    29,
);

$limit = 16;

$other_posts_in_tag = get_posts( array(
    'tag_id'           =>  $tag_id,
    'posts_per_page'   => $limit + count( $array_of_post_ids_to_skip ),
    'suppress_filters' => false,
));
 
foreach ( $other_posts_in_tag as $post ){
    if ( in_array( $post, $array_of_post_ids_to_skip ) ){
        continue;
    }
    // здесь сама логика;
}

Ссылки

Автор: Кобзарёв Михаил

Русский разработчик с 20-ти летним стажем. Работаю с PHP, ООП, JavaScript, Git, WordPress, Битрикс, Joomla, Drupal, Opencart, DLE, Laravel, Moonshine, SuiteCRM.

Оптимизирую сайты под Google Page Speed, настраиваю импорты для больших магазинов на WooCommerce + WP All Import. Пишу плагины на заказ. Все мои услуги.

Веду блог о разработке, дайджест в телеграмме и в ВК.

Вы всегда можете нанять меня.

Комментарии
Подписаться
Уведомить о
guest

6 комментариев
Межтекстовые Отзывы
Посмотреть все комментарии
Игорь Тронь
5 лет назад

Я делал так для пагинации, поэтому еще дополнительно вычислял offset. Да, метод хорош

Admirus
Admirus
5 лет назад

А как правильно сделать с таким кодом по Вашему примеру

global $wp_query;

   $svifi = get_the_title();

   $pag = (isset($_GET[‘pages’])) ? $_GET[‘pages’] : 1;

   $args = ( array(

   ‘s’ => $svifi,

   ‘sentence’ => true,

   ‘posts_per_page’ => 5, // сколько похожих постов нужно вывести,

   ‘post_type’ => ‘post’,

   ‘paged’ => $pag,

   ‘post__not_in’ => array($post->ID), //Не выводить текущую запись

   ‘orderby’=>date, // Условие сортировки рандом

) );

$my_query = new WP_Query( $args );

if( $my_query->have_posts() ) :

phpinfo()
Игорь Тронь
5 лет назад
Ответить на  Admirus

Ну и еще потребуется дополнительная проверка: если нам в наборе попался наш текущий ID, то использовать шестой элемент, если нет, то шестой не использовать.

Предыдущая запись
Следующая запись

Давайте дружить
в Telegram

Авторский блог вашего покорного слуги в Telegram про web, программирование, алгоритмы, инструменты разработчика, WordPress, Joomla, Opencart, Laravel, Moonshine, фильмы и сериалы