実現したいこと
WordPress(REST API + WP_Query)で商品一覧APIを自作しています。
プラグインは使わず、ACFのカスタムフィールドを含めた検索を実現したいのですが、
どうしても検索結果が 0件 になってしまい詰まっています。
REST API(/custom/v1/products)で以下の検索を実現したいです。
- フリーワード検索(検索窓1つ)
- 製品型番検索(ACF:model_number)
- 製品名検索(ACF:product_name)
- 製品カテゴリ検索(ACF:product_category)
- メーカー固定(ACF:manufacturer が「アマダ / AMADA」)
発生している問題・分からないこと
検索パラメータ keyword を指定すると 常に0件
keyword を外すと通常の一覧は取得できる
ACFの値自体は管理画面では正しく登録されている
エラーメッセージ
error
1エラーメッセージは特にありません
該当のソースコード
PHP
1$args = [ 2 'post_type' => 'product', 3 'post_status' => 'publish', 4 'posts_per_page' => 12, 5 'paged' => $page, 6 'meta_query' => [ 7 'relation' => 'OR', 8 [ 9 'key' => 'manufacturer', 10 'value' => 'アマダ', 11 'compare' => 'LIKE', 12 ], 13 [ 14 'key' => 'manufacturer', 15 'value' => 'AMADA', 16 'compare' => 'LIKE', 17 ], 18 ], 19]; 20 21$keyword = $request->get_param('keyword'); 22if ($keyword) { 23 $args['meta_query'][] = [ 24 'relation' => 'OR', 25 [ 26 'key' => 'model_number', 27 'value' => $keyword, 28 'compare' => 'LIKE', 29 ], 30 [ 31 'key' => 'product_category', 32 'value' => $keyword, 33 'compare' => 'LIKE', 34 ], 35 [ 36 'key' => 'product_name', 37 'value' => $keyword, 38 'compare' => 'LIKE', 39 ], 40 ]; 41} 42
試したこと・調べたこと
- teratailやGoogle等で検索した
- ソースコードを自分なりに変更した
- 知人に聞いた
- その他
上記の詳細・結果
ACFの複数フィールドを OR 条件で検索する場合、
- meta_query の relation の正しい組み方は?
- manufacturer 条件と keyword 条件を
- 「メーカーAND(型番OR製品名ORカテゴリ)」にしたい場合のベストプラクティス
- この構成で 0 件になる場合に疑うべきポイント(meta_key名、保存形式など)
補足
特になし