PROBLEM: I’am trying to prevent execution of default WordPress query for custom category template. I have found a possible solution, but looks like it preventing execution of all post queries:
function _cancel_query( $query ) {
if ( !is_admin() && !is_feed() && is_search() ) {
$query = false;
}
return $query;
}
add_action( 'posts_request', '_cancel_query' );
Source: http://vadimk.com/2010/05/11/disable-wordpress-search-query/
‘@query->is_main_query()’ won’t work with ‘posts_request’ action. Is there any elegant way to prevent ONLY default WordPress query, allowing my code to handle getting posts, without performing useless operations?
WHY: I have to get featured posts, then fixed amount of normal posts without duplicate content, which implies that post query relies on featured query results, because there is no guarantee that in post query i find enough featured posts to populate featured box. And after all that i will have to add AJAX pagination – still without duplicate content.
EDIT #2: If you trying to perform WP_Query in ‘pre_get_posts’ as Rarst suggested (How to prevent execution of default query, while preserving ability to use WP_Query in template?):
“pre_get_posts runs before WP_Query has been setup. Some template tags and conditional functions that rely on WP_Query will not work. For example, is_front_page() will not work, although is_home()will work. In such cases, you will need to work directly with the query vars, which are passed to the pre_get_posts hook as an argument ($query in examples on this page).”
Source: https://codex.wordpress.org/Class_Reference/WP_Query
WP_Query will be initialized at this stage, before main query, and to avoid result like this ( check out log ) you have to wrap it :
if ($query->is_main_query()) {
$args = array();
$query = new WP_Query( $args );
}
LOG:
[30-Apr-2013 17:07:12 UTC] PHP Fatal error: Maximum function nesting level of '100' reached, aborting! in C:UsersserwisDropboxwwwXYZwp-includesfunctions.php on line 2769
[30-Apr-2013 17:07:12 UTC] PHP Stack trace:
[30-Apr-2013 17:07:12 UTC] PHP 1. {main}() C:UsersserwisDropboxwwwXYZindex.php:0
[30-Apr-2013 17:07:12 UTC] PHP 2. require() C:UsersserwisDropboxwwwXYZindex.php:17
[30-Apr-2013 17:07:12 UTC] PHP 3. wp() C:UsersserwisDropboxwwwXYZwp-blog-header.php:14
[30-Apr-2013 17:07:12 UTC] PHP 4. WP->main() C:UsersserwisDropboxwwwXYZwp-includesfunctions.php:779
[30-Apr-2013 17:07:12 UTC] PHP 5. WP->query_posts() C:UsersserwisDropboxwwwXYZwp-includesclass-wp.php:549
[30-Apr-2013 17:07:12 UTC] PHP 6. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesclass-wp.php:485
[30-Apr-2013 17:07:12 UTC] PHP 7. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 8. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 9. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 10. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 11. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 12. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 13. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 14. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 15. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 16. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 17. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 18. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 19. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 20. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 21. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 22. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 23. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 24. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 25. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 26. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 27. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 28. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 29. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 30. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 31. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 32. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 33. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 34. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 35. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 36. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 37. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 38. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 39. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 40. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 41. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 42. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 43. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 44. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 45. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 46. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 47. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 48. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 49. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 50. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 51. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 52. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 53. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 54. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 55. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 56. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 57. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 58. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 59. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 60. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 61. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 62. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 63. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 64. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 65. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 66. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 67. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 68. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 69. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 70. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 71. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 72. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 73. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 74. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 75. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 76. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 77. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 78. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 79. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 80. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 81. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 82. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 83. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 84. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 85. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 86. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 87. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 88. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 89. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 90. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 91. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 92. do_action_ref_array() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1924
[30-Apr-2013 17:07:12 UTC] PHP 93. call_user_func_array() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 94. gs_pre_get_posts() C:UsersserwisDropboxwwwXYZwp-includesplugin.php:487
[30-Apr-2013 17:07:12 UTC] PHP 95. WP_Query->__construct() C:UsersserwisDropboxwwwXYZwp-contentthemesroots-XYZlibcustom.php:14
[30-Apr-2013 17:07:12 UTC] PHP 96. WP_Query->query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:3059
[30-Apr-2013 17:07:12 UTC] PHP 97. WP_Query->get_posts() C:UsersserwisDropboxwwwXYZwp-includesquery.php:2972
[30-Apr-2013 17:07:12 UTC] PHP 98. WP_Query->parse_query() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1922
[30-Apr-2013 17:07:12 UTC] PHP 99. absint() C:UsersserwisDropboxwwwXYZwp-includesquery.php:1442
Completely canceling main query is pretty much high level madness, that involves subclassing
wp
class.I would:
pre_get_posts
withis_main_query()
checkI know it might be abit late for answer but I came across similar issue while making my test project. Here’s how I solved it.
@UPDATE:
Changed code to use normal function instead of anonymous one and made made code return ‘false’ instead of ‘SELECT 0 AS ID’ as it caused to return one dummy empty WP_Post object. Returning ‘false’ makes $wpdb->get_results() to bail early so no query is made.