質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.96%

【WP】検索結果でカスタムフィールド値を五十音順でソートしたい

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 2,325

k.r.

score 28

前提・実現したいこと

wordpressのキーワード検索結果とタグ検索結果を、
カスタムフィールドで作成した「ルビ」で、
五十音順ソートで表示したい。

発生している問題・エラーメッセージ

・カスタムフィールドで作成した
「ルビ=ruby」「誤表記=false」を検索対象に設定する事には成功。
・「ルビ=ruby」で五十音順でソートが実現できません。(投稿順にソートがかかる)
※誤表記の五十音は無視したい

該当のソースコード

■フィールド概要
フィールドラベル = ルビ
フィールド名 = ruby
フィールドタイプ = テキストエリア

function.php

// カスタムフィールドを検索対象に含めます。
function posts_search_custom_fields( $orig_search, $query ) {
     if ( $query->is_search() && $query->is_main_query() && ! is_admin() ) {
          // 4.4のWP_Query::parse_search()の処理を流用しています。(検索語の分割処理などはすでにquery_vars上にセット済のため省きます)
          global $wpdb;
          $q = $query->query_vars;
          $n = ! empty( $q['exact'] ) ? '' : '%';
          $searchand = '';

          foreach ( $q['search_terms'] as $term ) {
               $include = '-' !== substr( $term, 0, 1 );
               if ( $include ) {
                    $like_op  = 'LIKE';
                    $andor_op = 'OR';
               } else {
                    $like_op  = 'NOT LIKE';
                    $andor_op = 'AND';
                    $term     = substr( $term, 1 );
               }
               $like = $n . $wpdb->esc_like( $term ) . $n;
               // カスタムフィールド用の検索条件を追加します。
               $search .= $wpdb->prepare( "{$searchand}(($wpdb->posts.post_title $like_op %s) $andor_op ($wpdb->posts.post_content $like_op %s) $andor_op (custom.meta_value $like_op %s))", $like, $like, $like );
               $searchand = ' AND ';
          }
          if ( ! empty( $search ) ) {
               $search = " AND ({$search}) ";
               if ( ! is_user_logged_in() )
                    $search .= " AND ($wpdb->posts.post_password = '') ";
          }
          return $search;
     }
     else {
          return $orig_search;
     }
}
add_filter( 'posts_search', 'posts_search_custom_fields', 10, 2 );
// カスタムフィールド検索用のJOINを行います。
function posts_join_custom_fields( $join, $query ) {
     if ( $query->is_search() && $query->is_main_query() && ! is_admin() ) {
          // group_concat()したmeta_valueをJOINすることでレコードの重複を除きつつ検索しやすくします。
          global $wpdb;
          $join .= " INNER JOIN ( ";
          $join .= " SELECT post_id, group_concat( meta_value separator ' ') AS meta_value FROM $wpdb->postmeta ";
          $join .= " WHERE meta_key IN ( 'false','ruby' ) ";
          $join .= " GROUP BY post_id ";
          $join .= " ) AS custom ON ($wpdb->posts.ID = custom.post_id) ";
     }
     return $join;
}
add_filter( 'posts_join', 'posts_join_custom_fields', 10, 2 );

// 検索結果ルビ五十音順に設定
function customize_main_query($query) {

    if ( is_admin() || ! $query->is_main_query() )
        return;

    if ( $query->is_search() ) {
    $query->set( 'posts_per_page', '100' );
    $query->set( 'order', 'ASC');
    $query->set(
        'meta_query',
             array(
              'relation' => 'AND',
                  array(
                    'key' => 'ruby',
                       )
                   )
               );
}

    if ( $query->is_tag() ) {
    $query->set( 'posts_per_page', '100' );
    $query->set( 'order', 'ASC');
    $query->set(
        'meta_query',
             array(
              'relation' => 'AND',
                  array(
                    'key' => 'ruby',
                       )
                   )
               );
}

}
add_action( 'pre_get_posts', 'customize_main_query' );


search.php

<?php get_header(); ?>
        <div class="container">
<?php get_sidebar(); ?>

<?php
    global $wp_query;
    $total_results = $wp_query->found_posts;
    $search_query = get_search_query();
?>

                <main class="main">
                    <div class="contents">
                        <section class="searchResults">
                            <h1 class="searchResults__title"><?php echo $search_query; ?> 」の検索結果</h1>
                            <section class="searchResults__body">
                            <ul class="searchResults__list">

<!-- 投稿情報 loop -->
<?php
if( $total_results >0 ):
if(have_posts()):
while(have_posts()): the_post();
?>

                                <li class="searchResults__listItem"><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></li>

<!-- /post -->
   <?php endwhile; endif; else: ?>

<?php echo $search_query; ?> に一致する情報は見つかりませんでした。

<?php endif; ?>

                            </ul>
                            </section>
                        </section>
                    </div>
                </main>
<?php get_sidebar(right); ?>
        </div>
<?php get_footer(); ?>


tag.php

<?php get_header(); ?>
        <div class="container">
<?php get_sidebar(); ?>

<?php
    global $wp_query;
    $total_results = $wp_query->found_posts;
    $search_query = get_search_query();
?>

                <main class="main">
                    <div class="contents">
                        <section class="searchResults">
                            <h1 class="searchResults__title"><?php single_tag_title(); ?> 」に関連する用語</h1>
                            <section class="searchResults__body">
                            <ul class="searchResults__list">

<!-- 投稿情報 loop -->
<?php
if( $total_results >0 ):
if(have_posts()):
while(have_posts()): the_post();
?>

                                <li class="searchResults__listItem"><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></li>

<!-- /post -->
   <?php endwhile; endif; else: ?>

<?php echo $search_query; ?> に一致する情報は見つかりませんでした。

<?php endif; ?>

                            </ul>
                            </section>
                        </section>
                    </div>
                </main>
<?php get_sidebar(right); ?>
        </div>
<?php get_footer(); ?>

試したこと

下記を参考に、カスタムフィールドを検索対象に設定しました。
http://wpcj.net/1363
下記を参考に、
ルビでの五十音順表示を試みましたが、実現できでおりません。
http://digipoke.com/archives/641

検索対象とする設定とルビでの五十音順表示の設定で、
打消しを起してる可能性を疑い、
試しに検索対象とする設定をコメントアウトした結果、文字通りただ検索対象から外れるだけでした。
お手引きよろしくお願いいたします。

補足情報(言語/FW/ツール等のバージョンなど)

html5    
css3    
php5.6    
mySOL5.6    
wordpress4.5.2

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

check解決した方法

0

orderbyの指定がされていないことが原因でした。

function.php

if ( $query->is_search() ) {
    $query->set( 'posts_per_page', '100' );
    $query->set( 'orderby', 'meta_value');//この記述を追加
    $query->set( 'order', 'ASC');


'orderby' => 'meta_value'
でカスタムフィールド文字列順で並び替えます。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.96%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる