この記事は最後に更新してから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


お勧め

comment_text(2018年5月27日 更新)

void comment_text( )
現在のコメント文を表示する。

is_main_site(2018年5月27日 更新)

bool is_main_site( int $site_id = null )
サイトがメインサイトか調べる。

get_the_author_meta(2018年5月27日 更新)

string get_the_author_meta( [ string $field = '' [ , mixed $user_id = false ] ] )
投稿者情報を取得する。

single_cat_title(2018年5月27日 更新)

string single_cat_title( [ string $prefix = '' [ , bool $display = true ] ] )
アーカイブページのカテゴリー名を取得し、パラメータ$displayがtrueならば表示する。$displayがfalseの場合は、文字列として返す。

get_users(2017年11月27日 更新)

array get_users( [ array $args = array() ] )
ユーザー情報を取得する。