get_all_page_ids() — возвращает IDы всех страниц на блоге

Функция возвращает массив, состоящий из ID всех страниц блога (имеется ввиду тип поста page).

get_all_page_ids()

Не имеет параметров.

В начале функция пытается получить значения из кэша WordPress, в случае, если кэш не содержит нужных значений, она вытаскивает их из базы при помощи следующего запроса:

$page_ids = $wpdb->get_col("SELECT ID FROM $wpdb->posts WHERE post_type = 'page'");

Как видите статус страниц игнорируется, то есть в массив будут включены не только опубликованные страницы, но и черновики, и страницы, находящиеся в корзине.

Подробно про правильное составление запросов к базе данных в WordPress я пишу здесь.

Пример

Давайте выведем массив, полученный в результате:

print_r(get_all_page_ids());
// Array ( [0] => 9 [1] => 19 [2] => 2 [3] => 14 [4] => 20 [5] => 64 [6] => 271 [7] => 622 )

Миша

Впервые познакомился с WordPress в 2009 году. С 2014 года меня можно встретить на WordCamp по всему миру — официальной конфе по WordPress, иногда там выступаю, но с 2019 выступаю только на тех, которые сам организовываю. Также периодически школа Epic Skills и LoftSchool приглашают меня вести у них уроки/вебинары.

Если вам нужна помощь с вашим сайтом или может даже разработка с нуля — пишите мне.

Оставить комментарий

Если вы хотите добавить код, не забудьте обернуть его в <pre lang="php"></pre>, в случае несоблюдения этого условия в 99% случаях ваш коммент будет удалён, а автор заблокирован. Печалька.