/**
* サイト内検索のカスタマイズ
*/
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->prepare("%{$word}%");
$search .= " AND (
-- 投稿タイトル
{$wpdb->posts}.post_title LIKE '{$search_word}'
-- 投稿コンテンツ
OR {$wpdb->posts}.post_content LIKE '{$search_word}'
-- 「タグ・カテゴリー」のSEO SIMPLE PACK設定情報
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
INNER JOIN {$wpdb->termmeta} AS tm ON t.term_id = tm.term_id
WHERE tm.meta_value LIKE '{$search_word}'
-- タイトル
AND ( tm.meta_key = 'ssp_meta_title'
-- ディスクリプション
OR tm.meta_key = 'ssp_meta_description' )
)
-- 「固定・投稿ページ」のSEO SIMPLE PACK設定情報
OR {$wpdb->posts}.ID IN (
SELECT distinct pm.post_id
FROM {$wpdb->postmeta} AS pm
INNER JOIN {$wpdb->posts} AS p ON pm.post_id = p.id
WHERE pm.meta_value LIKE '{$search_word}'
-- タイトル
AND ( pm.meta_key = 'ssp_meta_title'
-- ディスクリプション
OR pm.meta_key = 'ssp_meta_description'
-- キーワード
OR pm.meta_key = 'ssp_meta_keyword' )
)
) ";
}
}
}
return $search;
}
add_filter('posts_search','custom_search', 10, 2);
コメント