1

我需要 WP_Query 方面的帮助。我使用 OR 和 AND 关系使用元查询参数,但查询结果中似乎忽略了此参数。

这是我的代码:

$args = array(
    'orderby'           => 'date',
    'order'             => 'DESC',
    'post_type'         => 'my_custome_post_type',
    'posts_per_page'    => 1,
    'meta_query'        => array(
        'relation' => 'OR',
            array(
                'relation' => 'AND',
                array( 'author'     => $contact_id ),
                array( 'meta_key'   => 'my_meta', 'meta_value' => $user_id )
            ),
            array(
                'relation' => 'AND',
                array( 'author'     =>  $user_id ),
                array( 'meta_key'   => 'my_meta', 'meta_value' => $contact_id )  
            )
    )
);

$query = new \WP_Query( $args );
$response = $query->posts;

我已经尝试像这里建议的那样添加这个参数:

'suppress_filters'     => false,
'is_your_custom_query' => true, // your custom flag

即使我直接在查询中用任意数字替换 and 的值,查询仍然返回相同的结果$user_id$contact_id我不明白为什么它不起作用。

4

1 回答 1

1

感谢您的帮助 !

正如dafoxukmeta_key所建议的key,我必须逐个meta_value替换value。我还必须添加'compare' => 'LIKE'.

但在这种情况下,它不起作用。我还必须author_id在一个库存中post_meta,并通过以下方式更改array( 'author'=> $contact_id )条件:

array( 'key '   => 'meta_author_id', 'value' => $user_id, 'compare' => 'LIKE' )

所以最终的$args数组看起来像这样:

 $args = array(
            'orderby'           => 'date',
            'order'             => 'DESC',
            'post_type'         => 'my_custome_post_type',
            'posts_per_page'    => 1,
            'meta_query'        => array(
                'relation' => 'OR',
                    array(
                        'relation' => 'AND',
                            array( 'key '   => 'meta_author_id', 'value' => $user_id, 'compare' => 'LIKE' )
                            array( 'key '   => 'my_meta', 'value' => $user_id, 'compare' => 'LIKE '
                   array(
                        'relation' => 'AND',
                            array( 'key '   => 'meta_author_id', 'value' => $user_id, 'compare' => 'LIKE' )
                            array( 'key '   => 'my_meta', 'value' => $contact_id, 'compare' => 'LIKE' )
                    )
        );
于 2019-01-09T17:49:49.873 回答