4.4へのアップグレード後にカスタム分類クエリが壊れる


9

4.2から4.4にアップグレードしたところ、分類クエリが空になりました。アップグレード前は問題なく動作していました。

という名前のカスタム分類を登録しました'title'。これは、カスタム投稿タイプで使用され'sg-publications'ます。WPテンプレート階層に従って、taxonomy-title.phpデフォルトのクエリ引数を使用するというテンプレートを作成しました。これまでは、各パブリケーションをタイトルで正しく表示していました。

以下は、そのテンプレートの$ queried_objectおよび$ wp_query-> requestの出力です。

[queried_object] => WP_Term Object
    (
        [term_id] => 1256
        [name] => Stroupe Scoop
        [slug] => stroupe-scoop
        [term_group] => 0
        [term_taxonomy_id] => 1374
        [taxonomy] => title
        [description] => 
        [parent] => 0
        [count] => 30
        [filter] => raw
    )

[queried_object_id] => 1256

[request] => 
SELECT wp_posts.* 
FROM wp_posts 
INNER JOIN wp_term_relationships 
ON (wp_posts.ID = wp_term_relationships.object_id) 
WHERE 1=1 
AND wp_posts.post_title = 'stroupe-scoop' 
AND ( 
    wp_term_relationships.term_taxonomy_id 
    IN (1374)
    ) 
AND wp_posts.post_type = 'sg-publications' 
AND (wp_posts.post_status = 'publish' 
    OR wp_posts.post_status = 'private'
    ) 
GROUP BY wp_posts.ID 
ORDER BY wp_posts.post_date 
DESC 

上記のクエリで見られる問題はWHERE 1=1、何らかの理由でが検索している直後ですpost_title = 'stroupe-scoop'。これは正しくありません。つまり、分類用語のスラッグであり、投稿のタイトルではありません。実際、その行をコメント化してデータベースに対して実行すると、適切な結果が得られます。それでは、WPが4.4にアップグレードする前に追加していなかった場合(想定)に、WPがその条件を追加する原因は何ですか?

これがtaxonomy-title.phpです:

<?php
/**
 * @package WordPress
 * @subpackage Chocolate
 */
  global $wp_query;

  $quer_object = get_queried_object();
  $tax_desc    = $quer_object->description;
  $tax_name    = $quer_object->name;
  $tax_slug    = $quer_object->slug;

get_header();
get_sidebar();

$title = get_the_title( $ID );
$args  = array(
    'menu'            => 'new-publications',
    'container'       => 'div',
    'container_id'    => $tax_slug . '-menu',
    'menu_class'      => 'menu-top-style nav nav-tab',
    'menu_id'         => '',
    'echo'            => true,
    'fallback_cb'     => false,
    'before'          => '',
    'after'           => '',
    'link_before'     => '<i class="fa fa-chevron-circle-right fa-fw fa-2x"></i>',
    'link_after'      => '',
    'items_wrap'      => '<ul id="%1$s" class="%2$s">%3$s</ul>',
    'depth'           => 0,
    'walker'          => ''
);

?>

<div id="page-title">
  <h1><?php _e( 'Publications - ' . $tax_name, LANGUAGE_ZONE ); ?></h1>
  <p><?php _e( 'View our monthly newsletter and stay informed on the latest real estate news.', LANGUAGE_ZONE ); ?></p>

<?php wp_nav_menu($args); ?>

</div>

<div id="multicol">

<?php
if ( have_posts() ) : while ( have_posts() ) : the_post();

get_template_part( 'loop' , 'title' );

endwhile;
endif;
?>

</div><!-- end #multicol -->
<section class="page-text well"><?php _e( $tax_desc, LANGUAGE_ZONE ); ?></section>

<?php
get_footer();

そしてfunctions.phpにこのクエリフィルターがあります:

// use pre_get_posts to remove pagination from publications
function gd_publications_pagination( $query ) {
  if ( is_admin() || ! $query->is_main_query() )
    return;

  if ( is_tax('title') ) {
    // Display all posts for the taxonomy called 'title'
    $query->set( 'posts_per_page', -1 );
    return;
  }
}
add_action( 'pre_get_posts', 'gd_publications_pagination', 1 );

クエリコードはどこにありますか?テンプレートにある場合は、それを壊している部分を削除してみませんか?そうでない場合-クエリを生成するために何を使用しましたか?
モントリオール主義者、2015

カスタムクエリコードはありません。WPのデフォルトループを使用しています。私はテンプレート階層に従っているので、WPは(アップグレードの前に)分類のための正しいクエリパラメーターを生成する必要があります(また、生成する必要があります)。
Gary D

2
あなたの内容は何taxonomy-title.phpですか?functions.phpメインクエリにフィルターがあるかどうかを確認するためにテーマを調べましたか?
モントリオールの2015

回答:


5

のようなパブリッククエリ変数と一致する分類法のスラッグを使用することはお勧めしませんtitle

title 私はそれはあなたの問題を説明することができると思うので、クエリ変数は4.4で導入されました。

クラスのこの部分をチェックしてくださいWP_Query

    if ( '' !== $q['title'] ) {
        $where .= $wpdb->prepare( 
            " AND $wpdb->posts.post_title = %s", 
            stripslashes( $q['title'] ) 
        );
    }

たとえば、次のように使用した場合:

example.tld/?title=test

WordPressはここで何をすべきですか?分類クエリですか、タイトル検索ですか?

だから私はカスタム分類のスラッグを前に付けることをお勧めします、例えば

gary_title

名前の衝突を回避するため。

更新:

これがバグであることを指摘してくれた@ ocean90に感謝します。バグは4.4.1 で修正されます。


2
4.4での変更をお知らせしてくれてありがとう-命名の競合の疑いがありました。いくつかのテストを実行したらフォローします。
Gary D

数バージョン前までは、code管理タイプのバックエンド全体を等幅にしたため、投稿タイプを登録できませんでした。総称名は常に衝突の候補です。一方、WordPressは独自の内部にプレフィックスを付ける必要があります。
fuxia

はい、それだけでした。分類法の用語と関連するファイル名を矛盾しないスキームに変更すると、すべてが元に戻りました。更新されたWPコードを教えてくれてありがとう。
Gary D

@GaryDが再び稼働するのを聞いてうれしい
バージリー

古いインストールを手に入れたらテストする必要があります;-)プレフィックスチケットは確実にサポートしますが、近い将来、残念ながら@toscho
birgire
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.