PHP および MySQL インデックスの読み取り/書き込み比率とクエリ パフォーマンスに対するデータ量の影響
要約: インデックスはデータベースを改善するために使用される重要なツールの 1 つですクエリのパフォーマンス。この記事では、特定のコード例を使用して、PHP および MySQL インデックスの読み取り/書き込み比率とデータ量がクエリのパフォーマンスに及ぼす影響を調査します。
次のサンプル コードを考えてみましょう:
<?php // 创建连接 $conn = new mysqli("localhost", "username", "password", "database"); // 检测连接是否成功 if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } // 查询数据 $sql = "SELECT * FROM users WHERE age > 20"; $result = $conn->query($sql); // 处理查询结果 if ($result->num_rows > 0) { while($row = $result->fetch_assoc()) { echo "ID: " . $row["id"]. " - Name: " . $row["name"]. " - Age: " . $row["age"]. "<br>"; } } else { echo "0 结果"; } // 关闭连接 $conn->close(); ?>
上記のコードでは、クエリ操作に SELECT ステートメントを使用します。読み取り操作の頻度が高くても、データベース内に対応するインデックスがない場合、クエリのパフォーマンスは比較的低くなります。この問題を解決するには、年齢フィールドにインデックスを作成することでクエリのパフォーマンスを向上させることができます。具体的なステートメントは次のとおりです。
CREATE INDEX idx_age ON users (age);
上記の操作により、age フィールドに idx_age という名前のインデックスが作成されました。このようにして、SELECT ステートメントを実行するときに、MySQL はこのインデックスを取得に使用するため、クエリのパフォーマンスが大幅に向上します。
次のサンプル コードを考えてみましょう:
<?php $sql = "SELECT * FROM users WHERE age > 20"; $result = $conn->query($sql);
このコードでは、引き続き SELECT ステートメントを実行して、年齢が 20 歳以上のすべてのユーザーをクエリします。データベース内に 100,000 件のユーザー データがあるとしますが、データ量が多くなると、クエリのパフォーマンスにある程度の影響が生じます。
この問題を解決するには、適切なインデックスを作成することでクエリのパフォーマンスを向上させることができます。例として前述の idx_age インデックスを取り上げます。
CREATE INDEX idx_age ON users (age);
このインデックスを作成すると、MySQL はクエリ時にそのインデックスを使用するため、クエリのパフォーマンスが大幅に向上します。
上記は、PHP と MySQL のインデックスの読み書き比率とデータ量がクエリのパフォーマンスに及ぼす影響に関するこの記事の説明です。読者が使用する際の参考になれば幸いです。開発中のインデックス。
参考文献:
上記は参考値であり、実際のアプリケーションでは、状況に応じて調整および拡張することをお勧めします。
以上がPHP および MySQL インデックスの読み取り/書き込み比率とデータ量はクエリのパフォーマンスにどのような影響を与えますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。