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

各投稿記事で設定されているカスタムフィールドの値を取得するには

説明

投稿記事ごとに設定されているカスタムフィールドの値は get_post_meta関数で取得できるが、すべての投稿記事で設定されているカスタムフィールドの値を一覧を取得する関数が見当たらない。カテゴリーや投稿タグのようにそれぞれの値と実際に使用されている投稿記事件数を取得したいのだが、探し方が悪いのか見つからないのだ。
カスタムフィールドに関連する関数の多くは、/wp-includes/meta.phpに定義されているのだが、上から下まで目を通してみても目的の関数が見当たらなかった。需要があれば定義されていてもおかしくないわけで、どうやらそういった需要はなかったということらしい。
まあ、定義されていないものは作ればいい。実際に作った関数はこんな感じ(関数名はそれっぽくしてみた)。
function get_post_meta_values( $meta_key = '' ) {
	global $wpdb;
	if ( !is_string( $meta_key ) || trim( $meta_key ) == '' )
		return false;
	$query = $wpdb->prepare(
		"SELECT meta_value, count(*) AS count FROM $wpdb->postmeta
		WHERE meta_key = %s GROUP BY meta_value", $meta_key );
	return $wpdb->get_results( $query );
}
このget_post_meta_values関数は、パラメータ$meta_keyで指定されたカスタムフィールドの値を配列を返すもの。配列内のカスタムフィールドの値はオブジェクトでmeta_valueフィールドにはカスタムフィールドの値が、countフィールドには登録数(≒投稿数)が格納されている。使い方はこんな感じ。
$addr1_values = get_post_meta_values( 'addr1' );
foreach ( $addr1_values as $addr1_value ) {
	// 値は $addr1_value->meta_value に
	// 登録数は $addr1_value->count に
}
さて関数の説明を少しだけ。ポイントになっているグローバル変数$wpdbは、データベースについて様々な操作を行う重要なオブジェクト。postmetaフィールドには、カスタムフィールドの情報を保存しているテーブル名が格納されている。prepareメソッドを使ってデータベースを操作するためのSQL文を作成し、get_resultsメソッドでSQLを実行。ここではデータベースからカスタムフィールドの値情報を取得している。
最近、カスタムフィールドを使うか、カスタムタクソノミーを使ったほうがいいのか悩むことがある。結果的にはよりお手軽なカスタムフィールドを使うケースがほとんどなんだけどね。

最終更新 : 2011年09月16日 19:44


お勧め

flush_rewrite_rules(2015年9月24日 更新)

void flush_rewrite_rules( [ bool $hard = true ] )
リライトルールを更新する。

shortcode_atts(2018年5月27日 更新)

array shortcode_atts( array $pairs, array $atts )
ショートコードの無効な属性値を除外する。属性が省略されている場合は、デフォルト値を設定する。

the_weekday(2012年1月16日 更新)

void the_weekday( )
投稿日の曜日を表示する。

wp_loginout(2018年5月27日 更新)

void wp_loginout( [ string $redirect = '' ] )
閲覧者がログインしているかどうかを調べ、ログインしていなければログインページのリンクを、ログイン済みならばログアウトページのリンクを表示する。

has_term(2012年1月17日 更新)

bool has_term( [ mixed $term = '' [ , string $taxonomy = '' [ , mixed $post = null ] ] ] )
投稿記事にタクソノミーが付属しているか調べる。