この記事は最後に更新してから1年以上経過しています。

カスタムフィールドで並び替え

説明

WordPressでは複数の投稿記事を取得する際、並び順の指定を省略すると投稿日時の降順になる。並び順は、投稿日時だけでなく、更新日時、投稿名、記事タイトル、コメント数のほか、カスタムフィールドも指定できる。

投稿記事を拡張するカスタムフィールドの値は基本的に文字列になるので、並び順はその文字列の比較となる。まずは文字列として比較して並び替えする方法を確認する。

テストで使用した投稿記事の情報は次の通り。

ID投稿タイトル投稿日時カスタムフィールド
発売日
カスタムフィールド
価格
81商品12012-08-09 14:04:272013-08-0120
83商品22012-08-09 14:46:052013-08-0910000
85商品32012-08-09 14:47:582013-08-03900

query_posts関数やWP_Queryクラスでカスタムフィールドの値を並び順で指定する場合は、クエリパラメータとしてカスタム名を指定する必要がある。例えば、WP_Queryクラスを使って'発売日'というカスタムフィールドで並び替えを行う場合は次のように指定する。

$result = new WP_Query( array( 'meta_key'=>'発売日', 'orderby'=>'meta_value' ) );

検索結果は次の順になる。

ID投稿タイトル投稿日時カスタムフィールド
発売日
カスタムフィールド
価格
83商品22012-08-09 14:46:052013-08-0910000
85商品32012-08-09 14:47:582013-08-0390
81商品12012-08-09 14:04:272013-08-012000

次にカスタムフィールドの'価格'で並び替えてみる。

$result = new WP_Query( array( 'meta_key'=>'価格', 'orderby'=>'meta_value' ) );

この場合の検索結果は次の順になる。

ID投稿タイトル投稿日時カスタムフィールド
発売日
カスタムフィールド
価格
85商品32012-08-09 14:47:582013-08-03900
81商品12012-08-09 14:04:272013-08-0120
83商品22012-08-09 14:46:052013-08-0910000

このような結果になるのは、カスタムフィールドの値を文字として比較するためである。では、数値として並び替えるにはどのようにすればいいかというと、'orderby'パラメータを'meta_value_num'に変更すればいい。

$result = new WP_Query( array( 'meta_key'=>'価格', 'orderby'=>'meta_value_num' ) );

この場合の検索結果は次の順になる。

ID投稿タイトル投稿日時カスタムフィールド
発売日
カスタムフィールド
価格
83商品22012-08-09 14:46:052013-08-0910000
85商品32012-08-09 14:47:582013-08-03900
81商品12012-08-09 14:04:272013-08-0120

このようにイメージ通りの並び順にできた。

目的に応じて'meta_value'と'meta_value_num'をうまく使い分けるのがポイント。まあ、そんなわけで忘れないようにメモっとく。


最終更新 : 2013年08月09日 17:45


お勧め

set_transient(2019年4月23日 更新)

bool set_transient( string $transient, mixed $value [ , int $expiration = 0 ] )
トランジェントの値を設定する。

wp_should_replace_insecure_home_url(2021年3月19日 更新)

bool wp_should_replace_insecure_home_url()
コンテンツ内のサイトアドレス('home')をhttpからhttpsに書き換えるべきか調べる。

get_oembed_response_data(2018年12月7日 更新)

mixed get_oembed_response_data( mixed $post, int $width )
oEmbedレスポンス情報を取得する。

apply_filters(2022年11月8日 更新)

mixed apply_filters( string $tag, mixed $value [ , ...$args ] )
フィルターを実行する。

get_next_post_link(2015年5月28日 更新)

string get_next_post_link( [ string $format = '%link »' [ , string $link = '%title' [ , bool $in_same_cat$in_same_term = false [ , mixed $excluded_categories$excluded_terms = '' [ , string $taxonomy = 'category' ] ] ] ] ] )
直後の投稿ページのリンクを取得する。