Mysql 查询发布自定义字段:ACF中继器内的检查列表
我试图查询所有在repeater字段中选中了特定复选框的帖子 我发现这是一个主题3和主题4的混合体,但我自己无法完成,我的第一次尝试是查询所有帖子并只打印一个选中的项目: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
<?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的所有帖子,我现在在问题中补充道。