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

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

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

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

1090閲覧

カスタムフィールドを使った第2ソートがうまくいかない

swest

総合スコア13

WordPress

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2019/06/16 02:43

編集2019/06/16 02:48

WordPress 5.2.1を使用しています。

やりたいこと

WP_QUERYでカスタムフィールド2つの値を使って第1、第2ソートを指定して並び替える。

name, title, year の3つがカスタムフィールドで、それぞれの記事がこのような具合です。

投稿タイトルnamekanayear
ABCICHIROいちろう1982
TTTICHIROいちろう1983
BBBJIROじろう1984
GGGSABUROさぶろう1994
AAASABUROさぶろう1983

問題点

第1、第2ソートとも基準がカスタムフィールドである場合、ソートがうまくいきません。

うまくいくパターン(カスタムフィールドが一方のみ) 第1:投稿タイトル  第2:name 第1:name   第2:投稿タイトル うまくいかないパターン(カスタムフィールドを1つ使用) 第1:year     第2:name ←うまくいかない 第1:name     第2:kana ←うまくいかない 第1:kana     第2:year ←うまくいかない

やってみたこと

とりあえず、それぞれ一つだけを基準にソートしてみたのですが、うまくいったので入力データ自体は大丈夫かと思います。

↓1つだけのソートは問題なし

PHP

1 2//投稿タイトルでソート 3$param = array( 4 'post_type' => array('post'), 5 'orderby' => 'title', 6 'order' => 'ASC', 7); 8 9//カスタムフィールドでソート 10$param = array( 11 'post_type' => array('post'), 12 'orderby' => 'meta_value', 13 'meta_key' => 'name', //kana, yearもうまくいく 14 'order' => 'DESC', 15); 16

どちらかのみカスタムフィールドの場合も第2ソートも問題なく反映できました。
↓カスタムフィールドがどちらか一方でも問題なし

PHP

1$param = array( 2 'post_type' => array('post'), 3 'orderby' => array('name' => 'ASC' , 'title'=>'ASC' ), 4 'meta_key' => 'name' 5);

↓うまくいかないです

カスタムフィールド2つの場合、うまくいかないです。

PHP

1$param = array( 2 'post_type' => array('post'), 3 'orderby' => array('name' => 'ASC' , 'year'=>'DESC' ), 4 'meta_query' => array( 5 array( 6 'key' => 'name', 7 ), 8 array( 9 'key' => 'year', 10 ) 11 ) 12);

そもそも条件2つともカスタムフィールドのやり方がよくわからくて、色々と調べて試行錯誤したのですが、よくわかりませんでした。

参考にした記事

1.関数リファレンス/WP Query
2.WordPress4.0から使えるようになった複雑な’oderby’を使ってみる
3.wordpress カスタムフィールドの値でソート(複数項目)


そもそも
● カスタムフィールドが複数の場合、従来使っていた'meta_key'には何かいれなければならないのか

● 'meta_query'を上記のような使い方であっているのか(meta_keyを入れない代わりに使用?)
● サイトによっては 指定キー名に「meta_」とつけているものもあり、仕様がわからない。こちらもためしてみたが、うまくいかず。。

等いまいちわからないことだらけでした。


どなたか詳しい方、ご教示&やり方を教えていただけますと幸いです。

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

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

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

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

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

guest

回答2

0

自己解決

お騒がせ致しました。自己解決できました。

↓下記サイトに載っている一番下のコードを変更することで解決できました。
WordPress Development Stack Exchange

PHP

1//第1ソートを「name」、第2ソートを「year」にした例 2$param = array( 3 'post_type' => array('post'), 4 'meta_query' => array( 5 'relation' => 'AND', 6 'N' => array( 7 'key' => 'name' 8 ), 9 'Y' => array( 10 'key' => 'year', 11 ) 12 ), 13 'orderby' => array('Y' => 'ASC' , 'N'=>'DESC' ) 14);

meta_queryの中に更に配列を作り別名をつけ、ソートをかけるというやり方です。

▼ つまりこうです ▼

PHP

1$param = array( 2 'post_type' => array('post'), 3 'meta_query' => array( 4 'relation' => 'AND', 5 '【第1ソート】' => array( 6 'key' => '【対象のカスタムフィールド1】' 7 ), 8 '【第2ソート】' => array( 9 'key' => '【対象のカスタムフィールド2】', 10 ) 11 ), 12 'orderby' => array('【第1ソート】' => 'ASC' , '【第2ソート】'=>'DESC' ) 13 14//【第1ソート】、【第2ソート】の名前は適当でOK 15 16);

投稿2019/06/16 08:13

swest

総合スコア13

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

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

0

たとえば「TTT」の「name」は「ICHIRO」で、「year」は「1983」ですよね。

なので「TTT」を取得するならこういう感じになります。

php

1 'meta_query' => array( 2 'relation'=>'AND', 3 array( 4 'key' => 'name', 5 'value'=>'ICHIRO', 6 'compare'=>'=' 7 ), 8 array( 9 'key' => 'year', 10 'value'=>'1983', 11 'type'=>'NUMERIC', // 'value' が数字のときに必要 12 'compare'=>'=' 13 ) 14 )

その他の指定についてもこちらを見ながらだとできると思います。

わからなければまたお聞きください。

投稿2019/06/16 04:21

chikachi

総合スコア33

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

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

swest

2019/06/16 06:35

すみません、質問の意図がよく伝わっていないみたいです。 任意のデータを取り出すのはできるんです。問題はその後のソート(並び替えの話)です。 SQLでいうと最後のORDER BYですね。 例えば、 複数の取得結果を取得したあと(上記のテーブルのようになったとする) 【name】で並び替えた場合、【name】に同じ値をもつ行があった場合、その中で【投稿日】順に並びますよね?そこを【投稿日】ではなく【year】で更に並び替えたいわけです。(いわゆる2重ソート)。 ----- わざわざ丁寧にURLまで付けてのご回答ありがとうございます。 もう少し調べてみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問