Как ограничить количество сообщений, которые получает WP_Query?
-
-
Просто 'posts_per_page=5'Just `'posts_per_page=5'`
- 0
- 2015-03-18
- Pieter Goosen
-
Я пользуюсь этим,но вот нашел все сообщения.Если я обращаюсь к свойству `found_posts`,оно говорит больше,чем 5. Я хочу,чтобы мой запрос содержал только 5 сообщений.Является ли это возможным?@PieterGoosenI use that, but that found all the posts. If I access to the `found_posts` property, it says a higher number than 5. I want my query to hold only 5 posts. ¿Is it possible? @PieterGoosen
- 0
- 2015-03-18
- EliasNS
-
Вы не должны устанавливать параметрnopaging,установив для него значениеtrue,вы получите ** все ** сообщения.You should not set the `nopaging` parameter, setting that to true means to get **all** posts
- 0
- 2015-03-18
- Pieter Goosen
-
@PieterGoosen Если я не устанавливаю параметрnopaging,он получает значение по умолчаниюfalse,поэтому на главной странице отображается 5 сообщений,но в запросе содержится больше.Добавляю изображение к вопросу.@PieterGoosen If I don't set the `nopaging` parameter it gets the default that is `false`, so the frontpage shows 5 posts, but the query holds more. I add an image to the question.
- 0
- 2015-03-18
- EliasNS
-
Ваши комментарии сбивают с толку,вы просили ограничить количество сообщений на странице до 5,вот что вы получите.Теперь вы говорите (перечитайте свой предыдущий комментарий :-)) запрос содержит больше.Пожалуйста,объясни.Вы не можете установитьposts_per_page,а затем использоватьno_paging,для которого установлено значениеtrue,в том же запросе,это либоposts_per_page ** ИЛИ **nopaging установлено вtrueYour comments are confusing, you asked to limit the amount of posts shown on a page to 5, that is what you get. Now, you say (reread your previous comment :-)) the query holds more. Please explain. You cannot set posts_per_page and then use no_paging set to true in the same query, it is either posts_per_page **OR** nopaging set to true
- 0
- 2015-03-18
- Pieter Goosen
-
Мой вопрос говорит "получает".Я думаю,что если запрос содержит больше сообщений,чем показано,он выполняет больше работы,чем необходимо.Я просто хочу знать,можно ли этого избежать.Мне не нужны результаты со скрытой навигацией.My question says "gets". I think that if the query holds more posts that the shown ones, it is doing more work than needed. I just want to know if it is possible to avoid that. I don't want navigable results with a hidden navigation.
- 0
- 2015-03-18
- EliasNS
-
Запрос не будет содержать больше сообщений,о которых вы просили.Если вы попросите 5,будет получено 5 сообщений,если будет более 5 сообщений,соответствующих требованиям.Выполните `var_dump ()` вашего запроса,например,если ваша переменная запроса - `$ query`,выполните` var_dump ($ query->posts) `.Вы увидите только 5 запрошенных сообщенийThe query will not hold more posts that you have asked for. If you ask for 5, 5 posts will be retrieved if there is more than 5 posts that matches the requirements. Do a `var_dump()` of your query, like if your query variable is `$query`, do `var_dump( $query->posts )`. You will only see the 5 posts you queried for
- 0
- 2015-03-18
- Pieter Goosen
-
5 ответ
- голосов
-
- 2015-03-18
Думаю,теперь я понимаю,что вы пытаетесь сделать. Когда вы запускаете пользовательский запрос с помощью
WP_Query
и устанавливаете ограничение на получение только 5 сообщений на страницу,запрос будет извлекать только 5 сообщений,и этот запрос будет содержать только 5 сообщений, НО для разбивки на страницыWP_Query
по-прежнему просматривает всю базу данных и считает все сообщения,соответствующие критериям запроса.Это можно увидеть,если посмотреть на свойства запроса
$found_posts
и$max_num_pages
. Возьмем пример:У вас есть 20 сообщений,относящихся к типу сообщений по умолчанию
post
. Вам только нужны последние 5 сообщений без разбивки на страницы. Ваш запрос выглядит так$ q=новый WP_Query ('posts_per_page=5');
-
var_dump ($ q- >posts)
,как и ожидалось,предоставит вам последние 5 сообщений -
echo $ q- >found_posts
даст вам20
-
echo $ q- >max_num_pages
даст вам4
Воздействие этой дополнительной работы минимально на сайтах с несколькими сообщениями,но это может оказаться дорогостоящим,если у вас есть сайт с сотнями или тысячами сообщений. Это пустая трата ресурсов,если вам когда-либо понадобятся только 5 последних сообщений
Существует недокументированный параметр
no_found_rows
,который использует логические значения,которые вы можете использовать,чтобы сделать ваш запрос залогом после того,как он нашел 5 нужных вам сообщений. Это заставитWP_Query
не искать больше сообщений,соответствующих критериям,после получения количества запрошенных сообщений. Этот параметр уже встроен вget_posts
,поэтомуget_posts
немного быстрее,чемWP_Query
,хотяget_posts
использует < код> WP_QueryЗаключение
В заключение,если вы не собираетесь использовать разбиение на страницы в запросе,всегда разумно использовать
'no_found_rows=true'
в вашем запросе,чтобы ускорить процесс и сэкономить на трате ресурсов.I think that now I understand what you are trying to do. When you run a custom query with
WP_Query
and set the limit to get only 5 posts per page, only 5 posts will be retrieved by the query and that query will only hold 5 posts, BUT for the sake of pagination,WP_Query
still runs through the whole database and counts all the posts that matches the criteria of the query.That can be seen when you look at the
$found_posts
and$max_num_pages
properties of the query. Lets take an example:You have 20 posts belonging to the default post type
post
. You only need the latest 5 posts without pagination. Your query looks like this$q = new WP_Query( 'posts_per_page=5' );
var_dump( $q->posts )
will give you the latest 5 posts as expectedecho $q->found_posts
will give you20
echo $q->max_num_pages
will give you4
The impact of this extra work is minimal on sites with only a few posts, but this can gt expensive if you are running a site with hundreds or thousands of posts. This is a waste of resources if you are only ever going to need the 5 latest posts
There is an undocumented parameter called
no_found_rows
which uses boolean values which you can use to make your query bail after it found the 5 posts you need. This will forceWP_Query
not to look for any more posts mathing the criteria after it has retrieved the amount of posts queried. This parameter is already build intoget_posts
, that is whyget_posts
is a bit faster thanWP_Query
althoughget_posts
usesWP_Query
Conclusion
In conclusion, if you are not going to use pagination on a query, it is always wise to
'no_found_rows=true'
in your query to speed things up and to save on wasting resources. -
- 2015-03-18
После разговора с @Pieter Goosen по поводу комментариев к вопросу я думаю,что смогу ответить на вопрос и объяснить свою ошибку.
Дело в том,что
found_posts
сбивал меня с толку.Я думаю,что это число извлеченных сообщений,но это не так. Это количество сообщений,соответствующих критериям .Это похоже на то,чтоWP_Query
состоит из двух частей: одна для поиска (всех) сообщений,а другая для получения содержимого при проверке параметровpagination
.Итак,у нас есть свойство$post_count
,которое представляет собой количество извлеченных сообщений (Codex говорит:The number of posts being displayed
),которое,конечно же,равно числу вposts_per_page
и количество элементов в свойстве массива$posts
.Итак,
WP_Query
не выполняет бесполезной работы,как я думал ^^Надеюсь,это поможет другим!
After the conversation with @Pieter Goosen on the comments of the question, I think I can answer the question and explain my mistake.
The key is that
found_posts
was confussing me. I thougth that, that number is the posts retrieved but is not. It is the number of posts that match the criteria. It's like theWP_Query
had 2 parts: one for finding (all) the posts, and other for fetching the content, when it checks for thepagination
parameters. So we have the$post_count
property that is the number of posts fetched (Codex saysThe number of posts being displayed
), that of course is equal to the number onposts_per_page
parameter, and the number of items on the$posts
array property.So
WP_Query
is not doing any useless work, as I thought ^^Hope this helps others!
-
Смотрите мой ответ.Думаю,я понимаю о чем вы :-)See my answer. I think I understand what you mean :-)
- 0
- 2015-03-18
- Pieter Goosen
-
Да!Вы сделали это очень хорошо: D Наконец-то у меня появился способ сделать это,и я все понимаю=D Спасибо,@PieterGoosen!Yes! You did it very well :D Finally I got the way to do it, and I understand all =D Thanks @PieterGoosen!
- 0
- 2015-03-19
- EliasNS
-
Готово!Он расширил мой собственный ответ ^^ @PieterGoosenDone! It extended my own answer ^^ @PieterGoosen
- 0
- 2015-03-19
- EliasNS
-
- 2015-03-18
Хорошо,у вас есть тип сообщения "blog_posts",и вы хотите получить 5 сообщений этого типа.Вот что вам нужно сделать
$args = array( 'post_type' => 'blog_posts', 'posts_per_page' => '5', ); $query = new WP_Query($args);
Приведенный выше запрос вернет 5 сообщений типа 'blog_posts',если это не пользовательский тип сообщения,просто замените его следующим образом
'post_type' => 'posts',
если вы хотите получить все сообщения,замените его следующим образом:'posts_per_page' => '-1',
,для получения дополнительных сведений WP QueryOk , lets you have post type called 'blog_posts' , and you want to fetch 5 posts of that post type . Here is what you need to do
$args = array( 'post_type' => 'blog_posts', 'posts_per_page' => '5', ); $query = new WP_Query($args);
The above query will return 5 posts of type 'blog_posts' , if it is not a custom post type , then just replace like this
'post_type' => 'posts',
if you want to fetch all posts then replace like this'posts_per_page' => '-1',
, for more details WP Query-
Смотрите,пожалуйста,комментарии к вопросу.See the comments on the question, please.
- 0
- 2015-03-18
- EliasNS
-
- 2015-03-18
Я знаю,что @ user1750063 упомянул код,но попробуйте это
$args = array ( 'post_type' => 'custom_post', 'nopaging' => false, 'posts_per_page' => '5', 'order' => 'DESC', 'orderby' => 'ID', ); $query = new WP_Query( $args ); if ( $query->have_posts() ) { while ( $query->have_posts() ) { $query->the_post(); // display content } } else { // display when no posts found } wp_reset_postdata(); // Restore original Post Data
I know that @user1750063 has mentioned the code but try this
$args = array ( 'post_type' => 'custom_post', 'nopaging' => false, 'posts_per_page' => '5', 'order' => 'DESC', 'orderby' => 'ID', ); $query = new WP_Query( $args ); if ( $query->have_posts() ) { while ( $query->have_posts() ) { $query->the_post(); // display content } } else { // display when no posts found } wp_reset_postdata(); // Restore original Post Data
-
id недопустим как значение orderby,аpagination - недопустимый параметр`id` is invalid as an `orderby` value and `pagination` is an invalid parameter
- 0
- 2015-03-18
- Pieter Goosen
-
pagination - недопустимый параметр.Вы имеете в виду 'nopaging'=>true '?Если да,то я получу ВСЕ сообщения.Я не этого хочу.@PieterGoosen Я думаю,он имеет в виду `ID`.`pagination`is not a valid parameter. You mean `'nopaging' => true`? If yes, then I'll get ALL posts. That's not what I want. @PieterGoosen I think he means `ID`.
- 0
- 2015-03-18
- EliasNS
-
orderby предназначен для отображения заказа,верно?Это не вредит значению/параметруnopaging. @PieterGoosen,почему ID и orderby недействительны?Вы можете прояснить суть дела?orderby is for displaying the order, right? It does not harm the nopaging value/ parameter. @PieterGoosen why is ID & orderby is invalid? Can you clarify the point?
- 0
- 2015-03-18
- Shreyo Gi
-
Это должен быть `ID`,а не`id`It should be `ID`, not `id`
- 0
- 2015-03-18
- Pieter Goosen
-
- 2020-06-18
Я бы ограничился настраиваемыми полями,проверьте этот пример запроса ниже:
$wp_query = new WP_Query("orderby=DESC&post_type=portfolio&meta_key=FeaturedProject&meta_value=1&posts_per_page=6");
Он вернет 6 избранных проектов.
I would limit it with custom fields, check this query sample below:
$wp_query = new WP_Query("orderby=DESC&post_type=portfolio&meta_key=FeaturedProject&meta_value=1&posts_per_page=6");
It will return 6 Featured projects.
Я изучал Google и WPSE,и единственное,что я вижу постоянно,- это использование
showposts
,который устарел.Я знаком с
WP_Query
и подумал,что если я установлю дляposts_per_page
свой предел (например,5),а дляnopaging
-true
,это будет выглядеть примерно так: « Хорошо,я дам вам только 5 сообщений ».Но это не работает.Как я могу это сделать?