質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.35%
WordPress

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

Q&A

解決済

1回答

3136閲覧

カスタムフィールド(繰り返し・入れ子)の時の文字検索

hirokinger

総合スコア2

WordPress

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

0グッド

0クリップ

投稿2021/04/17 14:48

wordpressの
カスタム投稿・カスタムフィールド(ACF)で作られた記事でテキスト検索をさせたいです。

条件を指定して、get_postsでテキストが含まれている記事一覧を表示しようとしていて、
色々なサイトを調べると、
meta_keyとmeta_valueを設定するか、
meta_queryの中で、keyとvalue を設定するかのどちらかということは調べられました。

ただ、繰り返しフィールド・条件フィールドが複数あり、繰り返しフィールドの中に更に入れ子で繰り返しフィールドなど、結構複雑なカスタムフィールドのため、
一つの記事にmeta_keyやkeyがものすごい数がつくられてしまっているため、
meta_key・keyをどう設定すればよいのかがわかりません。

meta_valueの中身がすべて検索できれば問題無いので、
meta_keyやkeyを省略してみたのですが、動かないようでして。

keyを設定せずに、指定したposttype内のmeta_valueだけで絞り込みをする方法はありますでしょうか。

いま、書いているコードは下記のような感じです。

$args = array( 'post_type' => 'school', 'posts_per_page' => -1, 'meta_key' => '', 'meta_value' => $_POST[ 'sname' ], 'meta_compare' => 'LIKE' ); $posts = get_posts( $args );

と、

$args = array( 'post_type' => 'school', 'posts_per_page' => -1, 'meta_query' => array( 'relation' => 'OR', array( 'key' => '', 'value' => $_POST[ "sname" ], 'compare' => 'LIKE' ), ) ); $posts = get_posts( $args );

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

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

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

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

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

guest

回答1

0

ベストアンサー

繰り返しフィールド等のサブフィールドに対して、検索する方法は、ACF ドキュメントのDocumentation Guides Query posts by custom fieldsの「4. Sub custom field values」の例のように posts_where フックを用いる方法になります。

日本語の情報だと、ACF Repeater Field内をmeta_queryする が,ドキュメントに同じことをしていると思います。

投稿2021/04/18 07:16

編集2021/04/18 07:17
CHERRY

総合スコア25218

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

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

hirokinger

2021/05/07 04:49

動作しました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問