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


お勧め

wp_authenticate(2022年1月31日 更新)

WP_User | WP_Error wp_authenticate( string $username, string $password )
ユーザー認証を行う。

wp_send_json_success(2020年12月10日 更新)

void wp_send_json_success( [ mixed $response = null [ , int $status_code = null [ , int $options = 0 ] ] ] )
AJAXリクエストの成功レスポンスとしてJSON情報を返す。

wp_oembed_get(2014年11月16日 更新)

mixed wp_oembed_get( string $url [ , mixed $args = '' ] )
oEmbedに対応したページの埋め込み用コンテンツを取得する。

setup_postdata(2014年11月16日 更新)

bool setup_postdata( stdClass $post )
投稿記事に関連するグローバル変数を設定する。

the_permalink(2018年5月27日 更新)

void the_permalink( [ mixed $post = 0 ] )
現在の投稿データのパーマリンクを表示する。