如何解决具有多个键和多个值的Wordpress Meta_query
我有如下所示的WP查询代码,以检查帖子是否与所有post_Meta匹配>获取该帖子,否则创建新帖子,但是结果始终显示我的帖子只有loaicua = cua-chinh
和loaiphong = phong-khach
而且我不知道为什么@@
有人可以告诉我代码哪里错了,非常感谢
foreach( $Meta_array as $Meta ) { $i++;
if (!isset($page_query_args[$Meta['key']])) {
$page_query_args[$Meta['key']]['key'] = $Meta['key'];
$page_query_args[$Meta['key']]['value'][] = $Meta['value'];
$page_query_args[$Meta['key']]['type'] = 'CHAR';
$page_query_args[$Meta['key']]['compare'] = 'IN';
} else {
$page_query_args[$Meta['key']]['value'][] = $Meta['value'];
}
if( $i == sizeof( $Meta_array ) ) {
$page_query_args = array_values($page_query_args);
}
}
if( sizeof( $Meta_array ) > 1 ) {
$page_query_args['relation'] = 'AND';
}
$page_query = new WP_Query(
array(
'post_type' => 'page','orderby' => 'date','order' => 'DESC','Meta_query' => $page_query_args,)
);
$ page_query_args的输出
array(3) {
[0]=>
array(4) {
["key"]=>
string(7) "loaicua"
["value"]=>
array(1) {
[0]=>
string(9) "cua-chinh"
}
["type"]=>
string(4) "CHAR"
["compare"]=>
string(2) "IN"
}
[1]=>
array(4) {
["key"]=>
string(9) "loaiphong"
["value"]=>
array(3) {
[0]=>
string(11) "phong-khach"
[1]=>
string(9) "phong-ngu"
[2]=>
string(12) "phong-tre-em"
}
["type"]=>
string(4) "CHAR"
["compare"]=>
string(2) "IN"
}
["relation"]=>
string(3) "AND"
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。