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

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

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

Q&A

解決済

1回答

4099閲覧

WORDPRESS 複数のカスタムフィールドを含めた検索と並び替え (再投稿)

nats

総合スコア22

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

0グッド

0クリップ

投稿2018/04/23 16:07

一度解決済としましたが、改善されていなかったので再投稿いたします。

WP_Queryにて記事を検索する場合、複数の組み合わせで行った際、一部だけ適応されないです。

構成は以下です。

1.「pickup」にチェックが入った記事を抽出
2.「event_date」(デートピッカー)を参照し、本日以降の記事を対象とする
3.「event_date」の日時で並び替え

この3の部分が実行されません。
3の部分だけを入力すると実行されます。1.2.の部分だけを入力しても実行されます。

いくつか試してみましたが原因がわからず...。ご教授くださいませ。
何卒宜しくお願い致します。

$currnet_date = date_i18n( 'y/m/d' ); $args = array( 'posts_per_page' => 10, 'meta_key' => 'pickup', 'meta_value' => true, 'meta_query' => array( 'relation' => 'AND', array( 'key' => 'event_date', 'value' => $currnet_date, 'compare' => '>=', 'type' => 'DATE' ),array( 'key' => 'event_date', 'orderby' => 'meta_value', 'order'=> 'ASC' ) ) );

また追加質問となりますが、event_dateの検索で、当日に該当する1件を表示する方法も、動きません。
wordpress codex
の参考から、実現したい事と同等の内容があったので、ままやってみた(以下コードは多少変更していますが)のですが、それで動かないのでお手上げです。

valueの内容が間違っているかと思いましたが、

<?php echo $todayEvent; ?>は本日の日時が表示されてます。 <?php the_title(); ?>は最新の記事が表示されています。

他のコードが関与しないように、こちらのコードのみを配置したindex.phpで作業しております。
上記もあわせて、何が問題があるのか教えていただれば幸いです。

宜しくお願い致します。

<?php $todayEvent = date('Y.m.d D'); $param = array( 'posts_per_page' => 1, 'meta_key' => 'event_date', 'meta_value' => $todayEvent, 'meta_compare' => '>', ); $wp_query = new WP_Query($param); if($wp_query->have_posts()): while($wp_query->have_posts()) : $wp_query->the_post(); ?> <strong>TODAY EVENT - <?php echo $todayEvent; ?></strong> <h1><?php the_title(); ?></h1> </a> <?php endwhile; endif; ?>

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

meta_queryにorderbyが入っているのが問題では。

【複数のカスタムフィールドを条件にして、かつカスタムフィールドでソート | げんげんブログ】
http://www.sakataya.sakura.ne.jp/wp/?p=39

【関数リファレンス/WP Query - WordPress Codex 日本語版】
http://wpdocs.osdn.jp/関数リファレンス/WP_Query#Order_.26_Orderby_Parameters

投稿2018/04/23 16:18

kei344

総合スコア69407

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

nats

2018/04/23 16:51

参考のURLで無事解決する事ができました!!!!!! 本当にありがとうございます。 orderbyの位置と、日付のデータがうまく取得できてなかったのが原因でした。 色々試行錯誤でソースを入れ替えても、組み合わせで答えにたどり着けなかったみたいです。 codexままのソースでも動かなかったのは、日付データをうまく取得できてなかったのかもしれません。 $todayEvent = date('Y.m.d D');をdate_i18n( 'y/m/d' )にしました。 本当にありがとうございます。10時間くらい時間取られていて、たった今まで悩ませていたので、本当に救世主です。誠にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問