目次
複合インデックスの基本構造
複合インデックスを効果的に利用する方法は?
複合インデックスを作成するための提案
注:インデックス障害の一般的なシナリオ

MySQL Composite Indexの例

Jul 12, 2025 am 01:36 AM

MySQL Composite Indexは、左端のプレフィックスの原理に従います。クエリ条件には、インデックスがインデックスを押す前に、インデックスの左端列を含める必要があります。 1.インデックス構造は、最初に名前でソートされ、次に順番に細分化された(名前、年齢、都市)など、定義の順に編成されます。 2。ヒット条件には、name = ...またはwhere name = ... ...およびage = ...などの左端列からの連続組み合わせが含まれます。 3.左端の列が含まれていない場合、年齢や都市のみが使用されている場合、ヒットすることはできません。 4.作成する場合、高分断された一般的に使用されるクエリフィールドをその前に配置する必要があり、冗長性と過度のインデックス作成を避ける必要があります。 5.関数の使用、またはインデックスサポートなしで、%の開始時にファジーマッチングがインデックスに失敗します。

MySQL Composite Indexの例

ジョイントインデックスとも呼ばれるMySQLの複合インデックスは、テーブルの複数の列に作成されたインデックスを指します。複合インデックスの合理的な使用は、クエリパフォーマンスを大幅に改善できますが、その原則を理解していない場合、それは悪影響を与える可能性があります。

MySQL Composite Indexの例

複合インデックスの基本構造

複合インデックスは、定義されたときに列の順に編成されます。たとえば、インデックス(name, age, city)を作成すると、インデックスは最初にnameでソートされ、次にnameが同じ場合にageでソートされ、最終的にcityでソートされます。

例えば:

MySQL Composite Indexの例
ユーザー(名前、年齢、都市)でインデックスIDX_NAME_AGE_CITYを作成します。

このステートメントは、 usersのテーブルのnameagecityの複合インデックスを作成します。

この構造により、クエリ条件を書き込むときに、左端の列から使用を開始するようにする必要があります。そうしないと、インデックスが有効になる場合があります。

MySQL Composite Indexの例

複合インデックスを効果的に利用する方法は?

複合インデックスを使用するための鍵は、「左端のプレフィックス」の原則です。つまり、クエリ条件には、インデックスを押すために左端インデックスに列を含める必要があります。

いくつかの一般的な状況:

  • WHERE name = 'Tom'はそれを打つことができます
  • WHERE name = 'Tom' AND age = 25ヒットすることができます
  • WHERE name = 'Tom' AND age > 20 AND city = 'Beijing'それを打つことができます
  • WHERE age = 25 AND city = 'Beijing' name
  • WHERE city = 'Beijing'もヒットしません

したがって、クエリステートメントを設計するときは、コンポジットインデックスの左端列から条件を開始して、インデックスをスキャンできるようにしてください。


複合インデックスを作成するための提案

複合インデックスを作成しても、いくつかの列を追加するだけではありません。いくつかの実用的な提案があります:

  • 非常に際立った列の前面
    たとえば、性別や年齢と比較して、年齢の差はより高く、それを前に置くのに適しています。

  • 一般的に使用されるクエリフィールドが推奨されます
    (user_id, status)クエリ条件として頻繁に使用する場合、これらの2つのフィールドは複合インデックスの形成に適しています。

  • 冗長なインデックスを避けてください
    たとえば、 (name, age)インデックスを既に持っている場合、前者はすでに後者のニーズをカバーできるため、 (name)インデックスを個別に作成する必要はありません。

  • インデックスを過剰に作成しないでください
    インデックス作成はクエリを高速化しますが、挿入と更新のパフォーマンスにも影響します。特に、執筆が大きく、読み取りが少ないテーブルでは、インデックスが多いほど負担が大きくなります。


注:インデックス障害の一般的なシナリオ

複合インデックスを作成したとしても、クエリメソッドが間違っている場合でも、インデックスを押すことはできません。

  • 機能や式でフィールドを操作します。
    ここで(create_time)= 2023
  • OR 、一部の条件はインデックスによってサポートされていません
  • たとえば、クエリには%から始まるファジーマッチがあります。
     「%トム」のような名前

    これらはインデックスの障害を引き起こし、特別な注意が必要です。


    基本的にそれだけです。複合インデックスは良いツールですが、適切な場所を使用して、その構造と使用ルールを理解して、パフォーマンスの利点に完全にプレイする必要があります。

    以上がMySQL Composite Indexの例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ホットトピック

MySQLでデータベースアクティビティを監査する方法は? MySQLでデータベースアクティビティを監査する方法は? Aug 05, 2025 pm 01:34 PM

usemysqlenterpriseauditpluginifenterpriseeditionbyEnablingItinconIntinconserver-audit = force_plus_permanentandcustomizeventsviaserver_audit_events;

オブジェクトレベルの特権でMySQLを保護します オブジェクトレベルの特権でMySQLを保護します Jul 29, 2025 am 01:34 AM

Tosecuremysqleffectivilly、useobject-levelprivilegestolimituseracesseracessbadeds.beginbyunderstanding thatobject-leveligesapplytodatabases、Tables、orcolumns、subfice finercontrolthangloblabliledeges.next、適用

財務データストレージのためにMySQLを最適化します 財務データストレージのためにMySQLを最適化します Jul 27, 2025 am 02:06 AM

MySQLは金融システムに最適化する必要があります。1。財務データを使用して、10進数タイプを使用した精度を確保する必要があり、タイムゾーンの問題を回避するために時間分野でデータを使用する必要があります。 2。インデックス設計は合理的でなければなりません。フィールドの頻繁な更新を避けてインデックスを構築し、クエリの順序でインデックスを組み合わせ、定期的に役に立たないインデックスをクリーンにします。 3.トランザクションを使用して、一貫性を確保し、トランザクションの粒度を制御し、長いトランザクションを回避し、それに埋め込まれた非コア操作を回避し、ビジネスに基づいて適切な分離レベルを選択します。 4。時間ごとに履歴データを分割し、コールドデータをアーカイブし、圧縮テーブルを使用してクエリ効率を向上させ、ストレージを最適化します。

Check Constraintsを使用してMySQLのデータルールを実施する方法は? Check Constraintsを使用してMySQLのデータルールを実施する方法は? Aug 06, 2025 pm 04:49 PM

MySQLは、バージョン8.0.16から効果的なドメインの完全性を強制するためのチェック制約をサポートしています。 1.テーブルを作成するときに制約を追加する:createTableを使用して、18歳以上、給与> 0、部門の制限値などのチェック条件を定義します。 2。テーブルを変更して制約を追加します。AlterTableadDconstraintを使用して、名前以外の名前などのフィールド値を制限します。 3.複雑な条件を使用する:終了日≥の日付や完了ステータスなどのマルチカラムロジックと式のサポートは、終了日を持つ必要があります。 4。制約の削除:AlterTabledRopConstraintを使用して、削除する名前を指定します。 5。注:mysql8.0.16、innodbまたはmyisamを引用する必要があります

MySQLデータベースにタグ付けシステムを実装する方法は? MySQLデータベースにタグ付けシステムを実装する方法は? Aug 05, 2025 am 05:41 AM

useamany-to-manyrelationshipwithunctiontabletolinkitemsandtagsviathreetables:アイテム、タグ、anditem_tags.2

大規模なMySQLテーブルを管理するためのベストプラクティス 大規模なMySQLテーブルを管理するためのベストプラクティス Aug 05, 2025 am 03:55 AM

大規模なテーブルを扱う場合、MySQLのパフォーマンスと保守性が課題に直面し、構造設計、インデックス最適化、テーブルサブテーブル戦略などから開始する必要があります。オーバーレイインデックスを使用して、クエリ効率を向上させます。スロークエリログを定期的に分析し、無効なインデックスを削除します。 2。パーティションテーブルの合理的な使用:クエリとメンテナンスの効率を改善するための時間範囲やその他の戦略に従ってパーティションをかけますが、分割と削減の問題に注意を払う必要があります。 3.分離とライブラリの分離の読み取りと書き込みを検討してください。ライブラリの分離とテーブルの分離は、大量のデータを備えたシナリオに適しています。ミドルウェアを使用して、トランザクションとクロスストアのクエリの問題を評価することをお勧めします。早期計画と継続的な最適化が重要です。

MySQLにすべてのデータベースを表示する方法 MySQLにすべてのデータベースを表示する方法 Aug 08, 2025 am 09:50 AM

MySQLにすべてのデータベースを表示するには、ShowDataBaseコマンドを使用する必要があります。 1.MySQLサーバーにログインした後、ShowDatabaseを実行できます。現在のユーザーがアクセスする許可があるすべてのデータベースをリストするコマンド。 2。information_schema、mysql、performance_schema、sysなどのシステムデータベースはデフォルトで存在しますが、許可が不十分なユーザーはそれを見ることができない場合があります。 3. selectschema_namefrominformation_schema.schemataを介してデータベースをクエリしてフィルタリングすることもできます。たとえば、システムデータベースを除外して、ユーザーが作成したデータベースのみを表示します。必ず使用してください

MySQLの既存のテーブルに主キーを追加する方法は? MySQLの既存のテーブルに主キーを追加する方法は? Aug 12, 2025 am 04:11 AM

既存のテーブルにプライマリキーを追加するには、AddPrimaryKey句を使用してAlterTableステートメントを使用してください。 1.ターゲット列にヌル値も重複もなく、notnullと定義されていることを確認してください。 2.単一列のプライマリキー構文は、変更可能なテーブル名AddPrimaryKey(列名)です。 3.マルチカラムの組み合わせプライマリキー構文は、変更可能なテーブル名AddPrimaryKeyです(列1、列2)。 4.列がnullを許可する場合、最初に変更を実行してnotnullを設定する必要があります。 5.各テーブルには1つの主キーのみがあり、追加する前に古いプライマリキーを削除する必要があります。 6.自分で増やす必要がある場合は、Modifyを使用してAuto_incrementを設定できます。操作前にデータを確認してください

See all articles