要約すれば:
テーブルを設計する場合:
索引:
要約: 適切なデータ型を使用し、適切なインデックスを選択する 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 ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。 以下もご興味があるかもしれません:
|
<<: Nginx 書き換えジャンプの適用シナリオの詳細な説明
>>: Vue+express+Socketでチャット機能を実現
序文IE の将来のすべてのバージョンで Web ページの外観が一貫していることを保証するために、IE...
123WORDPRESS.COM HTML チュートリアル セクションに戻るには、ここをクリックして...
目次成果を達成する利用可能なプラグインの紹介ニーズに応じてプラグインを選択するプラグインのインストー...
まず、github から nacos の圧縮パッケージをダウンロードします: https://git...
この記事では、ドラッグアンドドロップをJSオブジェクト指向で実装するための具体的なコードを参考までに...
システムの初期のパーティション分割により、オペレーティング システム内の対応する / パーティション...
目次1. はじめに2. オンデマンド属性モード3. 乱雑な遅延読み込み属性パターン4. クラスの唯一...
目次乱数を生成する0から1までの乱数を生成する指定された範囲内で乱数を生成します6桁のモバイル認証コ...
1. Nexusの設定1. Dockerプロキシを作成する外部ネットワーク ウェアハウスからローカル...
3つのモードブリッジ(ブリッジ モード)、NAT(ネットワーク アドレス変換モード)、ホストオンリー...
ここ数日、dockerでSpring Bootアプリケーションを実行する方法を勉強してきました。以前...
結果: コードロジックを実装するのが主な部分であり、具体的なページ構造を一つ一つ紹介することはありま...
<br />関連記事: innerHTML HTML DOM insertRow() メ...
MySQL では、ほとんどのインデックス (PRIMARY KEY、UNIQUE、INDEX、FUL...
以下は、Flex レイアウトを使用した棒グラフです。 HTML: <div class=&qu...