Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/232.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php wp_reset_query()wordpress-无法重置上一个查询_Php_Wordpress - Fatal编程技术网

Php wp_reset_query()wordpress-无法重置上一个查询

Php wp_reset_query()wordpress-无法重置上一个查询,php,wordpress,Php,Wordpress,我试图在一个页面上运行两个查询。 第一个显示自定义用户搜索的结果 第二个应该只是显示最近的记录,其中包含一些硬编码到查询中的自定义参数 我遇到的问题是,当运行自定义搜索时,两个查询都会受到影响,结果在两个位置都会更新 我已尝试放置这些wp_reset_postdata(); wp_reset_query();到处都是,但都没有 有人有什么想法吗 这是我的第一个问题 $args = array('post_type' => 'vacancy', 'post_status' => 'pu

我试图在一个页面上运行两个查询。 第一个显示自定义用户搜索的结果 第二个应该只是显示最近的记录,其中包含一些硬编码到查询中的自定义参数

我遇到的问题是,当运行自定义搜索时,两个查询都会受到影响,结果在两个位置都会更新

我已尝试放置这些wp_reset_postdata(); wp_reset_query();到处都是,但都没有

有人有什么想法吗

这是我的第一个问题

$args = array('post_type' => 'vacancy', 'post_status' => 'publish' ) );
add_filter( 'posts_where', 'posts_where_title', 10, 2 );
function posts_where_title( $where, &$wp_query ) {
global $wpdb;
$where .= ' AND (' . $wpdb->posts . '.post_title LIKE \'%' . esc_sql( like_escape( $_POST['post_title'] ) ) . '%\'';
$where .= ' OR ' . $wpdb->posts . '.post_content LIKE \'%' . esc_sql( like_escape( $_POST['post_title'] ) ) . '%\')';
return $where;
}
$the_query = new WP_Query( $args );
if ( $the_query->have_posts() ) : while ( $the_query->have_posts() ) : $the_query->the_post();
//display results ?>
<?php $i++;  endwhile;  endif;  
wp_reset_postdata();
wp_reset_query();?>
$args=array('post_type'=>'空缺','post_status'=>'发布');
添加过滤器('posts\u where','posts\u where\u title',10,2);
函数posts\u where\u title($where,&$wp\u query){
全球$wpdb;
$where.='和('.$wpdb->posts.'.post\u title像\''%'.esc\u sql(像\''escape($\u post['post\u title']))。%\';
$where.='或'$wpdb->posts.'.post\u内容如\'%'.esc\u sql(如\''escape($\u post['post\u title'])).%\';
返回$where;
}
$thew_query=newwp_query($args);
if($the_query->have_posts()):while($the_query->have_posts()):$the_query->the_post();
//显示结果?>
这是我的第二个问题

$args = array( 'post_type' => 'vacancy', 'posts_per_page' => 10 );
query_posts( "_vacancy_ends>=".date("Y-m-d")."&_vacancy_starts<=".date("Y-m-d")."&order=DESC" );
$loop = new WP_Query( $args );
while ( $loop->have_posts() ) : $loop->the_post();
//display results
endwhile;
wp_reset_postdata();
wp_reset_query();
$args=array('post\u type'=>'空缺','posts\u per\u page'=>10);

查询职位(“\u空缺\u结束>=”。日期(“Y-m-d”)。”和\u空缺\u开始您的问题是这一行:

query_posts( "_vacancy_ends>=".date("Y-m-d")."&_vacancy_starts<=".date("Y-m-d")."&order=DESC" );

请记住,这个过滤器将在您调用AddiaFixter之后设置的每个查询上运行。您可能需要考虑在不需要过滤器运行的情况下删除更多的过滤器:

remove_filter( 'posts_where', 'posts_where_title');

出于好奇,您的“空缺”结束和“空缺”开始参数是什么?这些自定义字段是否属于空缺职位类型?这是一个很好的问题解决了,解释也很好。新年快乐,非常感谢
add_filter( 'posts_where', 'posts_where_title', 10, 2 );
function posts_where_title( $where, &$wp_query ) {
    global $wpdb;
    $where .= ' AND (' . $wpdb->posts . '.post_title LIKE \'%' . esc_sql( like_escape( $_POST['post_title'] ) ) . '%\'';
    $where .= ' OR ' . $wpdb->posts . '.post_content LIKE \'%' . esc_sql( like_escape( $_POST['post_title'] ) ) . '%\')';
    return $where;
}
remove_filter( 'posts_where', 'posts_where_title');