🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

Q&A

解決済

1回答

1018閲覧

wordpressでカスタムフィールド、カテゴリー、タグ、ユーザー名を含めた検索がしたい

yoshidama

総合スコア4

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

0グッド

0クリップ

投稿2021/02/12 03:10

前提・実現したいこと

現在、wordpressで検索結果にカスタムフィールドを含めたいと思いこちらの記事(https://adambalee.com/search-wordpress-by-custom-fields-without-a-plugin/)をもとに作業を行っているのですが、カスタムフィールドだけでなく、カテゴリーやタグ、ユーザー名も含めたいと考えております。

私自身のスキルが低すぎるため解決することができず、wordpressの検索でカスタムフィールド、カテゴリー、タグ、ユーザー名を検索するための知恵をお貸し頂けたら幸いです。

該当のソースコード

/** * Extend WordPress search to include custom fields * http://adambalee.com */ /** * Join posts and postmeta tables * http://codex.wordpress.org/Plugin_API/Filter_Reference/posts_join */ function cf_search_join($join) { global $wpdb; if (is_search()) { $join .=' LEFT JOIN '.$wpdb->postmeta. ' ON '. $wpdb->posts . '.ID = ' . $wpdb->postmeta . '.post_id '; } return $join; } add_filter('posts_join', 'cf_search_join'); /** * Modify the search query with posts_where * http://codex.wordpress.org/Plugin_API/Filter_Reference/posts_where */ function cf_search_where($where) { global $wpdb; if (is_search()) { $where = preg_replace( "/(\s*".$wpdb->posts.".post_title\s+LIKE\s*(\'[^\']+\')\s*)/", "(".$wpdb->posts.".post_title LIKE $1) OR (".$wpdb->postmeta.".meta_value LIKE $1)", $where); } return $where; } add_filter('posts_where', 'cf_search_where'); /** * Prevent duplicates * http://codex.wordpress.org/Plugin_API/Filter_Reference/posts_distinct */ function cf_search_distinct($where) { global $wpdb; if (is_search()) { return "DISTINCT"; } return $where; } add_filter('posts_distinct', 'cf_search_distinct');

試したこと

こちらの記事(https://memo.dogmap.jp/2012/08/27/wordpress-custom-search/)のコードを参考に、「cf_search_where」部分で下記のようなことを試してみたのですが、検索することはできませんでした。

"(".$wpdb->posts.".post_title LIKE $1) OR (".$wpdb->posts.".post_content LIKE $1) OR (".$wpdb->posts.".post_author IN (SELECT distinct ID FROM {$wpdb->users} WHERE display_name LIKE $1) 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 $1 ) OR (".$wpdb->posts."t.slug LIKE $1) OR (".$wpdb->posts."tt.description LIKE $1) OR (".$wpdb->postmeta.".meta_value LIKE $1)", $where);

補足情報(FW/ツールのバージョンなど)

wordpress ver 3系

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

解決しましたので閉じます。

投稿2021/02/12 09:18

yoshidama

総合スコア4

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

CHERRY

2021/02/13 02:56

teratail のヘルプ [質問をした後に自己解決してしまった](https://teratail.com/help#resolve-myself) に 「自分で投稿した質問にも回答する事が可能です。質問文の内容を編集したりせず、回答を付けベストアンサーをクリックし解決済みにしてください。また後から読む人のためにも、具体的な解決手順を記載してください。」とありますので、回答欄の記載内容は、具体的な方法を記載していただけないでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問