Wordpress - 分页文章,按 meta_key 排序,仅限于当前分类

4

我试图从我的网站创建分页链接。


模式:


Serie | (category)
    |_ Temporada 1 (taxonomy: temporada)
            |_ Episodio 1 (posts 1 - meta_key: numeroepisodio)
            |_ Episodio 2 (posts 2 - meta_key: numeroepisodio)
            |_ Episodio 3 (posts 3 - meta_key: numeroepisodio)
            |_ Episodio 4 (posts 4 - meta_key: numeroepisodio)
            |_ ...
    |_ Temporada 2  (taxonomy: temporada)
            |_ Episodio 1 (posts 1 - meta_key: numeroepisodio)
            |_ Episodio 2 (posts 2 - meta_key: numeroepisodio)
            |_ Episodio 3 (posts 3 - meta_key: numeroepisodio)
            |_ Episodio 4 (posts 4 - meta_key: numeroepisodio)
            |_ ...

Another Serie 1
    |_ ...
Another Serie 2
    |_ ...

问题:


我创建帖子时,分页按日期排序。请帮助我使用meta_key按同一分类仅对当前类别进行排序。


代码:


<?php
    $prev_post = get_adjacent_post( true, '', true );
    $next_post = get_adjacent_post( true, '', false );

    if ( !is_a( $next_post , 'WP_Post' ) ) {
        $query_args = array (
        'post_type'         => 'post',
        'posts_per_page'    => -1,
        'meta_key'          => 'numeroepisodio',
        'orderby'           => 'meta_value meta_value_num',
        'order'             => 'DESC',
        'paged'             => $paged,
        'tax_query'         => array( 
                                array( 'taxonomy' => 'categry'),
                                array( 'taxonomy' => 'temporada') 
                        )
    );
        $oldest = get_posts($query_args);
        $next_post = $oldest[0];
    }
    if ( !is_a( $prev_post , 'WP_Post' ) ) {
        $latest = get_posts($query_args);
        $prev_post = $latest[0];
    }
?>
<?php if ( is_a( $prev_post , 'WP_Post' ) ) : ?>
<a href="<?php echo get_permalink( $prev_post->ID ); ?>"><div id="temporadas-dropdown"><i class="fa fa-caret-left"></i> ANTERIOR</div></a>
<?php endif; ?> 

<?php if ( is_a( $next_post , 'WP_Post' ) ) : ?>
<a href="<?php echo get_permalink( $next_post->ID ); ?>"><div id="temporadas-dropdown">SIGUIENTE <i class="fa fa-caret-right"></i></div></a>
<?php endif; ?> 

这是一个现场实例:http://series.enlatino.net/ver-online/silicon-valley/。非常感谢您的帮助!

1
你的代码中的tax_query中写着categry。 - amurrell
已修复,但这并没有改变任何事情。无论如何,谢谢。 - Ferrmolina
1个回答

1
我发现了这个:
<?php
/** Plugin Name: (#73190) Alter adjacent post link sort order */
function wpse73190_adjacent_post_sort( $orderby )
{
    return "ORDER BY p.menu_order DESC LIMIT 1";
}
add_filter( 'get_previous_post_sort', 'wpse73190_adjacent_post_sort' );
add_filter( 'get_next_post_sort', 'wpse73190_adjacent_post_sort' );

来自 wordpress.stackexchange.com - 这里会更好地解释,所以去看一下... 接受的答案是这样的,但基本上你可以用那个过滤器改变查询,有不同的过滤器 - where、join、sort 对于前一个和后一个都是如此。


完全不同的答案:

我不是很喜欢手动操作,但这个方法可能有效——虽然我没有测试过,而且我对分类法和WordPress数据库的完全理解还有所欠缺。

function get_adjacent_episode($post, $prev_or_next) {
    global $wpdb;
    
    $prev_or_next = ($prev_or_next === 'previous') ? 'DESC' : 'ASC';
    $operator = ($prev_or_next === 'previous') ? '<' : '>';
    
    $cur_episode = get_post_meta($post->ID, 'numeroepisodio', true);
    
    $query = sprintf("select p.ID from $wpdb->posts p 
        inner join $wpdb->postmeta m 
        on p.ID = m.post_id
        inner join $wpdb->terms_relationships r
        on p.ID = r.object_id
        where r.term_taxonomy_id = (select term_taxonomy_id from $wpdb->term_taxonomy where taxonomy = '%s' limit 1) 
        and p.post_type = 'post' and m.meta_key = '%s' and m.meta_value %s %s
        order by m.meta_key %s limit 1", 'temporada', 'numeroepisodio', $operator, $cur_episode, $prev_or_next);
        
    $adjacent_post = $wpdb->get_results($query);
    return $adjacent_post;
}

称之为:

$next_post = get_adjacent_episode($post, 'next');

$prev_post = get_adjacent_episode($post, 'previous');

请注意,查询仅具有select p.ID,因此您只能访问$next_post->ID,但如果需要,可以扩展此选择以捕获更多结果。


嗨@amurrell,感谢您的回复。我对您的答案的问题是..那是一个好的实践吗?直接查询数据库是否安全? - Ferrmolina
1
我鼓励你阅读关于wpdb对象的内容,特别是使用prepare来避免SQL注入的想法,我已经使用sprintf()实现了这一点。个人认为,另一种操作排序过滤器的解决方案可能会有点糊弄,并且效率更低...常见做法吗?不知道,这是一种更手动的方法,也许这使它更高级-不确定。 - amurrell

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接