Mysql 查询发布自定义字段:ACF中继器内的检查列表

Mysql 查询发布自定义字段:ACF中继器内的检查列表,mysql,wordpress,advanced-custom-fields,Mysql,Wordpress,Advanced Custom Fields,我试图查询所有在repeater字段中选中了特定复选框的帖子 我发现这是一个主题3和主题4的混合体,但我自己无法完成,我的第一次尝试是查询所有帖子并只打印一个选中的项目: <?php $args = array( 'post_type' => 'modalidade', 'posts_per_page' => -1, ); $loop = new WP_Query( $args ); ?> <?ph

我试图查询所有在repeater字段中选中了特定复选框的帖子

我发现这是一个主题3和主题4的混合体,但我自己无法完成,我的第一次尝试是查询所有帖子并只打印一个选中的项目:

<?php 

    $args = array(
        'post_type' => 'modalidade',
        'posts_per_page' => -1,
    );

    $loop = new WP_Query( $args );

?>


<?php

// check if the repeater field has rows of data
if( have_rows('horarios') ):

    // loop through the rows of data
    while ( have_rows('horarios') ) : the_row();

        $dia_da_semana = get_sub_field_object( 'dia_da_semana' );
        $horario = get_sub_field_object( 'horario' );

        if ( in_array(1, $dia_da_semana['value'])) {
            echo 'segunda';
            print_r( $horario['value']);
            echo '<br>';
        }

    endwhile;

endif;

?>  
但不要认为这是一个好的解决方案。也许有更好的方法来实现我的目标。

我使用了教程,对代码和数据结构进行了一点修改,并完成了它。最后的代码如下所示:

// filter
function my_posts_where( $where ) {

$where = str_replace("meta_key = 'time_%", "meta_key LIKE 'time_%", $where);
    return $where;
}

add_filter('posts_where', 'my_posts_where');

// args
$args = array(
    'posts_per_page'   => -1,
    'post_type'     => 'class',
    'meta_query'    => array(
        array(
            'key'       => 'time_%_day_of_week',
            'value'     => 'monday',
            'compare'   => 'LIKE'
        ),
    )
);

一个对我来说非常重要的改变是将'numberposts'=>-1替换为'posts\u per\u page'=>-1,以获得所有帖子。属性numberposts不起作用。

请更新您的问题,将您的相关代码包含在a中,并详细说明您迄今为止尝试了什么以及为什么不起作用。完成!谢谢你的提醒!你的WP查询在哪里?我只是查询CTP的所有帖子,我现在在问题中补充道。