MySQL 最適化戦略 (推奨)

MySQL 最適化戦略 (推奨)

要約すれば:

  1. 1. データベースの設計とテーブルの作成時にパフォーマンスを考慮する
  2. 2. SQLの記述を最適化する必要がある
  3. 3. パーティション、テーブル、データベース

テーブルを設計する場合:

  1. 1. フィールドで null 値を使用しないでください。null 値はクエリや最適化が難しく、余分なインデックス スペースを占有します。null ではなく、デフォルトの数値 0 を使用することをお勧めします。
  2. 2. BIGINT の代わりに INT を使用するようにしてください。負でない場合は、UNSIGNED を追加します (これにより、値の容量が 2 倍になります)。もちろん、TINYINT、SMALLINT、または MEDIUM_INT を使用する方が適切です。
  3. 3. 文字列型の代わりに列挙型または整数型を使用する
  4. 4. DATETIMEの代わりにTIMESTAMPを使用する
  5. 5. 1 つのテーブルにフィールドが多すぎないようにしてください。フィールド数は 20 に制限することをお勧めします。
  6. 6. IPを格納するために整数を使用する

索引:

  1. 1. インデックスは多ければ多いほど良いです。クエリに基づいてインデックスを作成する必要があります。WHERE コマンドと ORDER BY コマンドに関係する列にインデックスを作成することを検討してください。EXPLAIN を使用して、インデックスが使用されているか、またはテーブル全体のスキャンが実行されているかを確認できます。
  2. 2. WHERE 句のフィールドに NULL 値を使用しないでください。そうしないと、エンジンはインデックスの使用を中止し、テーブル全体のスキャンを実行します。
  3. 3. 値が 2 つまたは 3 つしかない「性別」フィールドなど、値の分布が非常にまばらなフィールドは、インデックス作成には適していません。
  4. 4. 文字フィールドのプレフィックスインデックスのみを作成する
  5. 5. 文字フィールドを主キーとして使用しないことをお勧めします。
  6. 6. 外部キーは不要、制約はプログラムによって保証される
  7. 7. UNIQUEを使わないようにし、プログラムに制約を守らせる
  8. 8. 複数列インデックスを使用する場合は、順序とクエリ条件の一貫性を保ち、不要な単一列インデックスを削除します。

要約: 適切なデータ型を使用し、適切なインデックスを選択する

SQL の記述を最適化する必要があります。

クエリ結果のレコードを制限するには、limitを使用します。

select * を避け、検索する必要があるフィールドをリストします。

サブクエリの代わりに結合を使用する

大きな削除または挿入ステートメントを分割する

スロークエリログをオンにすると、遅いSQLを見つけることができます。

列操作なし: SELECT id WHERE age + 1 = 10。データベース チュートリアル関数、計算式など、列に対するすべての操作はテーブル スキャンになります。クエリを実行するときは、操作を等号の右側に移動するようにしてください。

SQL 文はできるだけシンプルにする必要があります。1 つの SQL 文は 1 つの CPU でのみ実行できます。大きな文はロック時間を短縮するために小さな文に分割する必要があります。1 つの大きな SQL 文はデータベース全体をブロックする可能性があります。

OR を IN に書き換えます。OR の効率は n ですが、IN の効率は log(n) です。IN の数は 200 以内に抑えることをお勧めします。

実装には関数やトリガーは必要ありません

%xxx 形式のクエリを避ける

JOINは控えめに使用してください

比較には同じ型を使用します(例: '123' と '123'、123 と 123)

WHERE 句では != または <> 演算子の使用を避けてください。そうしないと、エンジンはインデックスを放棄し、テーブル全体のスキャンを実行します。

連続した値の場合は、IN ではなく BETWEEN を使用します: SELECT id FROM t WHERE num BETWEEN 1 AND 5

リスト データにテーブル全体を使用しないでください。LIMIT を使用してデータをページに分割します。ページ数は大きすぎないようにしてください。

エンジン:

マイISAM

行ロックはサポートされていません。読み取り時に読み取りが必要なすべてのテーブルがロックされ、書き込み時にテーブルに排他ロックが追加されます。

トランザクションはサポートされていません

外部キーはサポートされていません

クラッシュ後の安全な回復をサポートしていない

テーブルの読み取りとクエリの実行中にテーブルに新しいレコードを挿入する機能をサポートします。

BLOBとTEXTの最初の500文字のインデックス作成と全文インデックス作成をサポート

インデックスの遅延更新をサポートし、書き込みパフォーマンスを大幅に向上

変更されないテーブルについては、ディスク容量の使用量を大幅に削減するために圧縮がサポートされています。

翻訳

行ロックをサポートし、MVCCを使用して高い同時実行性をサポートします。

サポート業務

外部キーをサポート

クラッシュ後の安全な回復をサポート

全文インデックスはサポートされていません

一般的に、MyISAM は SELECT 集中型テーブルに適しており、InnoDB は INSERT および UPDATE 集中型テーブルに適しています。

パーティション、テーブル、データベース(読み取りと書き込みの分離)

上記は、編集者が紹介したMySQL最適化戦略の詳細な説明と統合です。皆様のお役に立てれば幸いです。ご質問がある場合は、メッセージを残してください。編集者がすぐに返信します。また、123WORDPRESS.COM ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。

以下もご興味があるかもしれません:
  • MySQLクエリで大文字と小文字を区別しない問題を解決する方法
  • MySQLがファントムリードを解決する方法の詳細な説明
  • Navicat を使用してリモート Linux MySQL データベースに接続するときに発生する 10061 不明エラーの詳細な説明
  • MySQLデータベースの追加、削除、変更操作の詳細な説明
  • シェルスクリプトを使用してMySQLにインデックスを追加する方法
  • MySQL 文字セットの文字化けとその解決方法
  • MySQLは遅いSQLを開始し、原因を分析します
  • MySQL は、元のデータと同じデータがある場合、更新ステートメントを再度実行しますか?
  • MySQLクエリが遅い場合の理由と解決策
  • 間違った MySQL コマンドをキャンセルしたい場合はどうすればいいですか?

<<:  Nginx 書き換えジャンプの適用シナリオの詳細な説明

>>:  Vue+express+Socketでチャット機能を実現

推薦する

IE8を閲覧するときにウェブサイトが自動的にIE7互換モードを使用するようにする

序文IE の将来のすべてのバージョンで Web ページの外観が一貫していることを保証するために、IE...

マークアップ言語 - HTML を学んだ後に何を学ぶべきか?

123WORDPRESS.COM HTML チュートリアル セクションに戻るには、ここをクリックして...

Vue は PDF.js を統合して PDF プレビューを実装し、透かしを追加する手順を実行します。

目次成果を達成する利用可能なプラグインの紹介ニーズに応じてプラグインを選択するプラグインのインストー...

springcloud alibaba nacos linux 設定の詳細なチュートリアル

まず、github から nacos の圧縮パッケージをダウンロードします: https://git...

ドラッグ効果を実現するための js オブジェクト指向メソッド

この記事では、ドラッグアンドドロップをJSオブジェクト指向で実装するための具体的なコードを参考までに...

Docker イメージのデフォルトの保存場所を変更する方法 (ソリューション)

システムの初期のパーティション分割により、オペレーティング システム内の対応する / パーティション...

JavaScript の遅延読み込み属性パターンに関する簡単な説明

目次1. はじめに2. オンデマンド属性モード3. 乱雑な遅延読み込み属性パターン4. クラスの唯一...

乱数、文字列、日付、検証コード、UUIDを生成するMySQLメソッド

目次乱数を生成する0から1までの乱数を生成する指定された範囲内で乱数を生成します6桁のモバイル認証コ...

イメージのアップロードとダウンロードに docker をプロキシするためのプライベート ライブラリとして nexus を使用する

1. Nexusの設定1. Dockerプロキシを作成する外部ネットワーク ウェアハウスからローカル...

VMWare ネットワーク アダプタの 3 つのモードの実装プロセスの分析

3つのモードブリッジ(ブリッジ モード)、NAT(ネットワーク アドレス変換モード)、ホストオンリー...

DockerでSpring Bootアプリケーションを実行する方法

ここ数日、dockerでSpring Bootアプリケーションを実行する方法を勉強してきました。以前...

Vue+nodeはオーディオ録音・再生機能を実現

結果: コードロジックを実装するのが主な部分であり、具体的なページ構造を一つ一つ紹介することはありま...

innerHTML を理解する

<br />関連記事: innerHTML HTML DOM insertRow() メ...

MySQL btree インデックスとハッシュ インデックスの違い

MySQL では、ほとんどのインデックス (PRIMARY KEY、UNIQUE、INDEX、FUL...

CSS の Flex レイアウトを使用してシンプルな縦棒グラフを作成する方法

以下は、Flex レイアウトを使用した棒グラフです。 HTML: <div class=&qu...