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

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

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

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

解決済

Wordpressのカスタムフィールドでの検索で特定の条件を追加すると処理に時間がかかる理由または調査方法を教えてください

himawari39
himawari39

総合スコア14

WordPress

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

2回答

1評価

1クリップ

195閲覧

投稿2022/05/20 04:14

編集2022/05/21 14:10

いつもお世話になっています。
Wordpressの記事をカスタムフィールドで絞り込む機能をつけたいと思っています。
こちらでご教示頂きながら、

php

<?php $args = array( 'meta_query' => array( 'relation' => 'AND', array( 'key' => 'Wall', 'value' => $_GET["WallMin"], 'compare' => '>=', 'type' => 'NUMERIC', ), array( 'key' => 'Wall', 'value' => $_GET["WallMax"], 'compare' => '<=', 'type' => 'NUMERIC', ), array( 'key' => 'BT', 'value' => $_GET["BTMin"], 'compare' => '>=', 'type' => 'NUMERIC', ), array( 'key' => 'BT', 'value' => $_GET["BTMax"], 'compare' => '<=', 'type' => 'NUMERIC', ), array( 'key' => 'KT', 'value' => $_GET["KTMin"], 'compare' => '>=', 'type' => 'NUMERIC', ), array( 'key' => 'KT', 'value' => $_GET["KTMax"], 'compare' => '<=', 'type' => 'NUMERIC', ), ), ); $my_query = new WP_Query($args); if ($my_query->have_posts()) : while ($my_query->have_posts()) : $my_query->the_post(); ?> <?php the_title(); ?><?php the_post_thumbnail(); ?><?php the_excerpt(); ?> <?php endwhile; endif; wp_reset_postdata(); ?>

という検索だとすぐに結果が出てくるようになったのですが、

php

<?php $args = array( 'meta_query' => array( 'relation' => 'AND', array( 'key' => 'Year', 'value' => $_GET["YearMin"], 'compare' => '>=', 'type' => 'NUMERIC', ), array( 'key' => 'Year', 'value' => $_GET["YearMax"], 'compare' => '<=', 'type' => 'NUMERIC', ), array( 'key' => 'Wall', 'value' => $_GET["WallMin"], 'compare' => '>=', 'type' => 'NUMERIC', ), array( 'key' => 'Wall', 'value' => $_GET["WallMax"], 'compare' => '<=', 'type' => 'NUMERIC', ), array( 'key' => 'BT', 'value' => $_GET["BTMin"], 'compare' => '>=', 'type' => 'NUMERIC', ), array( 'key' => 'BT', 'value' => $_GET["BTMax"], 'compare' => '<=', 'type' => 'NUMERIC', ), array( 'key' => 'KT', 'value' => $_GET["KTMin"], 'compare' => '>=', 'type' => 'NUMERIC', ), array( 'key' => 'KT', 'value' => $_GET["KTMax"], 'compare' => '<=', 'type' => 'NUMERIC', ), ), ); $my_query = new WP_Query($args); if ($my_query->have_posts()) : while ($my_query->have_posts()) : $my_query->the_post(); ?> <?php the_title(); ?><?php the_post_thumbnail(); ?><?php the_excerpt(); ?> <?php endwhile; endif; wp_reset_postdata(); ?>

のように

php

array( 'key' => 'Year', 'value' => $_GET["YearMin"], 'compare' => '>=', 'type' => 'NUMERIC', ), array( 'key' => 'Year', 'value' => $_GET["YearMax"], 'compare' => '<=', 'type' => 'NUMERIC', ),

を追加すると検索結果が表れるまで10秒程度かかってしまいます。
まだテスト段階で記事も2~3個の状況なのになぜこれを追加すると極端に時間が掛かるようになるのかわからず困っています。

カスタムフィールドの設定は「Advanced Custom Fields」というプラグインを利用しており、いずれのカスタムフィールドもタイプを数値にしてます。ラベル、名前、最小値、最大値が違うだけで、その他の設定は初期のままです。

php

array( 'key' => 'Year', 'value' => $_GET["YearMin"], 'compare' => '>=', 'type' => 'NUMERIC', ), array( 'key' => 'Year', 'value' => $_GET["YearMax"], 'compare' => '<=', 'type' => 'NUMERIC', ),

がない状態で

php

echo $_GET["YearMin"];

を表示させて見ても表示に時間が掛かることはありません。

KazuhiroHatano様からご教示頂きましたQuery Monitorの計測結果は

Yearを追加してもしなくても
64Q遅いクエリー2重複クエリー4
PHPエラー(10notice,675deprected)
でした。

確認すべき場所、改善点、疑わしい点などご教示お願いいたします。

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

WordPress

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。