У меня проблема с сочетанием мета-запросов "ИЛИ" и "И" отношений - PullRequest
2 голосов
/ 16 июня 2019

Я хочу создать фильтр с мета-полями. Я создаю мета-поля с помощью плагина ACF. Я хочу использовать или связать некоторые мета-поля, но они не работают, например, для фильтра, я выбираю «Мужской» и «Женский» для тренера мета-ключей.это показывает, что у меня нет сообщений, но одно сообщение имеет мета-значение как мужчина, но мой запрос не показывает их, но если я выбрал только "Мужской", этот запрос будет показывать мета-значения сообщения в сообщении array('Male')

Это дляAJAX фильтр на WordPress

       $args = [
            'posts_per_page' => - 1,
        ];

        if ( $minlength ) {
            $min_lenght_query[] = [
                'key' => 'duration',
                'value' => $minlength,
                'compare' => '>=',
                'type' => 'NUMERIC'
            ];
        }
        if ( $maxlength ) {
            $max_lenght_query[] = [
                'key' => 'duration',
                'value' => $maxlength,
                'compare' => '<=',
                'type' => 'NUMERIC'
            ];
        }
        if ( $minburn ) {
            $minburn_query[] = [
                'key' => 'calorie_burn_minimum',
                'value' => $minburn,
                'compare' => '>=',
                'type' => 'NUMERIC'
            ];
        }
        if ( $maxburn ) {
            $maxburn_query[] = [
                'key' => 'calorie_burn_maximum',
                'value' => $maxburn,
                'compare' => '<=',
                'type' => 'NUMERIC'
            ];
        }
        if ( $difficulty ) {
            $difficulty_query[] = [
                'key' => 'difficulty',
                'value' => $difficulty,
                'compare' => 'IN',
            ];
        }
        if ( $trainer ) {
            foreach ($trainer as $value) {
            $trainer_query[] = [
                'key' => 'trainer',
                'value' => $value,
                'compare' => 'LIKE',
            ];
            }

        }
        if ( $focus ) {
            foreach ($focus as $value) {
            $focus_query[] = [
                'key' => 'body_focus',
                'value' => $value,
                'compare' => 'LIKE',
            ];
            }
        }
        if ( $trainingtype ) {
            foreach ($trainingtype as $value) {
            $trainingtype_query[] = [
                'key' => 'training_type',
                'value' => $value,
                'compare' => 'LIKE',
            ];
            }
        }
        if ( $equipment ) {
            foreach ($trainingtype as $value) {
            $equipment_query[] = [
                'key' => 'equipment',
                'value' => $value,
                'compare' => 'LIKE',
            ];
            }
        }
        if ( $search ) {
            $args['s'] = $search;
        }
        if($sort == 'newest'){
            $args['orderby'] = [ 'date'=>'DESC' ];
        }elseif($sort == 'olders'){
            $args['orderby'] = [ 'date'=>'ASC' ];
        }elseif($sort == 'shortest'){
            $args['orderby'] = [ 'meta_value_num'=>'ASC' ];
            $args['meta_key'] = 'duration';
        }elseif($sort == 'longest'){
            $args['orderby'] = [ 'meta_value_num'=>'DESC' ];
            $args['meta_key'] = 'duration';
        }
$args['meta_query']=array(
        'relation' => 'AND',
        array($min_lenght_query),
        array($max_lenght_query),
        array($minburn_query),
        array($maxburn_query),
        array($difficulty_query),
        array('relation' => 'OR',$trainer_query),
        array('relation' => 'OR',$focus_query),
        array('relation' => 'OR',$trainingtype_query),
        array('relation' => 'OR',$equipment_query),
    );

1 Ответ

0 голосов
/ 16 июня 2019

Я нашел, как я могу это сделать после тестирования массивов

if ( $trainer ) {
            $trainer_query=array('relation' => 'OR',);
            foreach ($trainer as $value) {
            $trainer_query[] = [
                'key' => 'trainer',
                'value' => $value,
                'compare' => 'LIKE',
            ];
            }

        }

и использовать это в мета-запросе, и это решит мою проблему

$args['meta_query']=array(
        'relation' => 'AND',
        array($min_lenght_query),
        array($max_lenght_query),
        array($minburn_query),
        array($maxburn_query),
        array($difficulty_query),
        array('relation' => 'OR',$trainer_query),
        array('relation' => 'OR',$focus_query),
        array('relation' => 'OR',$trainingtype_query),
        array('relation' => 'OR',$equipment_query),
    );
...