Skip Navigation

[Resolved] get_view_query_results() memory usage

This support ticket is created 4 years, 6 months ago. There's a good chance that you are reading advice that it now obsolete.

This is the technical support forum for Toolset - a suite of plugins for developing WordPress sites without writing PHP.

Everyone can read this forum, but only Toolset clients can post in it. Toolset support works 6 days per week, 19 hours per day.

Sun Mon Tue Wed Thu Fri Sat
8:00 – 12:00 8:00 – 12:00 8:00 – 12:00 8:00 – 12:00 8:00 – 12:00 - -
13:00 – 17:00 13:00 – 17:00 13:00 – 17:00 13:00 – 17:00 13:00 – 17:00 - -

Supporter timezone: America/New_York (GMT-04:00)

This topic contains 4 replies, has 2 voices.

Last updated by JamesS2731 4 years, 6 months ago.

Assisted by: Christian Cox.

Author
Posts
#1672201

Hi there,

I have a quick question relating to my earlier support ticket (Views print pagination).

Using the get_view_query_results(), is there a way to avoid overloading the site when producing a large amount of results?

We're displaying 2,000 or so car owners and keep running out of memory. I can keep increasing the memory, but wanted to see if there was a better way? breaking down the request into chunks, etc.

I look forward to your thoughts.

Kind Regards
James

#1672603

Yes, pagination is usually a good way to break down a query into manageable chunks. You can use "limit" and "offset" in your arguments array as defined in the View shortcode documentation here to retrieve paginated result blocks: https://toolset.com/documentation/programmer-reference/views/views-shortcodes/#wpv-view

#1672641

Hi Christian, many thanks for your quick response. I use pagination for displaying the page results, but would this work for print/pdf output?

We want to provide print/pdf/csv links on the results pages and my issue so far has been that they only apply to the visible page.

We need to be able to print all pages from the results and, in some cases, there may be 30 - 40 pages.

I look forward to your thoughts.

Kind regards
James

#1673587

Views is optimized for displaying data onscreen, not generating massive reports like this. If I were trying to do something similar, I would try to generate a report directly from the database. To come up with the right query, you could use pagination with your get_view_query_results call. Turn on the Views debug tool in Toolset > Settings > Front-end Content, and it will display the paginated MYSQL query when the page is loaded. Then you can remove the LIMIT and OFFSET parameters and run the query directly on the database. Trying to get all these results on the front-end of the site is going to be impractical and probably not possible given WordPress and browser limitations.

#1678451

Many thanks Christian, we followed your advice and went for a direct db search.

Much appreciated.

Kind regards
James