時間も場所もお金も自由な生活を手に入れる人生を目指し中

【WordPress】サイト内検索にタグ/カテゴリー/カスタムフィールド を含める方法

WordPressのデフォルトの検索結果は、タイトルと本文しか検索対象ではありません。

タグ、カテゴリー、カスタムフィールドの全ても検索結果に含めたい場面に遭遇したので、その時の備忘録。

目次

検索条件の変更

検索条件を変更するため、function.phpに以下を記載する。

//サイト内検索のカスタマイズ
function custom_search($search, $wp_query) {
	global $wpdb;

	//検索ページ以外だったら終了
	if (!$wp_query->is_search)
	return $search;

	if (!isset($wp_query->query_vars))
	return $search;

	// タグ名・カテゴリ名・カスタムフィールド も検索対象にする
	$search_words = explode(' ', isset($wp_query->query_vars['s']) ? $wp_query->query_vars['s'] : '');
	if ( count($search_words) > 0 ) {
		$search = '';
		foreach ( $search_words as $word ) {
			if ( !empty($word) ) {
				$search_word = $wpdb->escape("%{$word}%");
				$search .= " AND (
						{$wpdb->posts}.post_title LIKE '{$search_word}'
						OR {$wpdb->posts}.post_content LIKE '{$search_word}'
						OR {$wpdb->posts}.ID IN (
							SELECT distinct r.object_id
							FROM {$wpdb->term_relationships} AS r
							INNER JOIN {$wpdb->term_taxonomy} AS tt ON r.term_taxonomy_id = tt.term_taxonomy_id
							INNER JOIN {$wpdb->terms} AS t ON tt.term_id = t.term_id
							WHERE t.name LIKE '{$search_word}'
						OR t.slug LIKE '{$search_word}'
						OR tt.description LIKE '{$search_word}'
						)
						OR {$wpdb->posts}.ID IN (
							SELECT distinct p.post_id
							FROM {$wpdb->postmeta} AS p
							WHERE p.meta_value LIKE '{$search_word}'
						)
				) ";
			}
		}
	}

	return $search;
}
add_filter('posts_search','custom_search', 10, 2);

タグ、カテゴリーに関する部分

以下のSQLがタグ名、カテゴリー名に一致したときを抽出する条件。
外したい場合は、この部分を消す。

OR {$wpdb->posts}.ID IN (
 SELECT distinct r.object_id
 FROM {$wpdb->term_relationships} AS r
 INNER JOIN {$wpdb->term_taxonomy} AS tt ON r.term_taxonomy_id = tt.term_taxonomy_id
 INNER JOIN {$wpdb->terms} AS t ON tt.term_id = t.term_id
 WHERE t.name LIKE '{$search_word}'
 OR t.slug LIKE '{$search_word}'
 OR tt.description LIKE '{$search_word}'
)

カスタムフィールドに関する部分

以下のSQLがカスタムフィールド に含まれるキーワードに一致した時を抽出する条件。
外したい場合は、この部分を消す。

OR {$wpdb->posts}.ID IN (
 SELECT distinct p.post_id
	FROM {$wpdb->postmeta} AS p
 WHERE p.meta_value LIKE '{$search_word}'
)

SQLを駆使すれば、他の項目を含めるなど、色々検索条件を追加することも可能。

目次
閉じる