admin管理员组文章数量:1316227
I have a WP Query code like below to check if have post match all post_meta > get that post, else create new post, but the result always show me a post have only loaicua = cua-chinh
and loaiphong = phong-khach
and i don't know why.
Can someone point out the error in the code below? I will appreciate any help.
<?php
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,
)
);
Output of $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"
}
本文标签: wp queryMetaquery with multiple keys and multiple values
版权声明:本文标题:wp query - Meta_query with multiple keys and multiple values 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1741997609a2410360.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论