1

我希望通过尝试使用以下日期来限制 get_posts() 结果,但它对我不起作用......

谁能告诉我我这样做是否正确?为什么没有按预期执行?

add_filter( 'posts_where', 'filter_dates_between' );

$args=array(
        'post_type'=>'log',
        'suppress_filters' => false,
        'post_status'=>'private',
        'numberposts'=> -1,
        'meta_key'=>'_wpcf_belongs_agent_id','meta_value'=>$agentId);

$logs=get_posts($args);

remove_filter( 'posts_where', 'filter_dates_between' );

这是过滤功能

function filter_dates_between( $where =''  ) {
                global $dateFrom,$dateTo,$wpdb;

                $where .= $wpdb->prepare( " AND post_date >= %s", $dateFrom );
                $where .= $wpdb->prepare( " AND post_date <= %s", $dateTo );

                return $where;
    }
4

1 回答 1

0

你的代码很好。我认为问题出在您传递的日期被视为字符串。

确保最终采用此示例格式

    "AND post_date >= '2009-03-01' AND post_date <= '2009-03-15'"

或者干脆

    "AND cast(post_date as datetime) between cast... AND cast...
于 2012-08-15T12:38:34.627 回答