要約すれば:
テーブルを設計する場合:
索引:
要約: 適切なデータ型を使用し、適切なインデックスを選択する 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でチャット機能を実現
ここでは、Jenkins コンテナを例に 3 つの方法を紹介します。方法1コンテナをイメージにパッケ...
仕事上、携帯電話に適応した Web ページ効果を作成する必要があります。ようやく完成しました。まずは...
最近、データベース関連の操作が多くなり、会社の既存の仕様はあまり包括的ではありません。インターネット...
element-uiを使用する場合、el-popoverというよく使われるコンポーネントがありますが...
目次1. React.Children.map 2. React.Children.forEach ...
現在、プロジェクトの要件により、フォームの送信を制御し、送信前にデータを検証および処理するために j...
この記事では、参考までに、簡単な英中辞典を実装するためのjsの具体的なコードを紹介します。具体的な内...
序文データ型変換とは何ですか?フォームまたはプロンプトを使用して取得されるデフォルトのデータ型は文字...
この記事では、Mysql WorkBenchのインストールと設定のグラフィックチュートリアルを参考ま...
一部のWebサイトでアップロードする場合、「参照」ボタンをクリックすると、[ファイルの選択]ダイアロ...
一番外側の boxF は 120 度回転し、2 番目の boxS は -60 度回転し、3 番目の ...
均等に分散されたレイアウトの場合、通常はネガティブ マージン方式を使用します。次の図は平均的なレイア...
1. はじめに最近、CentOS での開発には多くの不便があることがわかりました。Windows/M...
ソフトウェア開発者は、ネットワーク アプリケーションがどのように動作するかを階層的に完全に理解してい...
1. ファイアウォールの基本的な使い方起動する: systemctl は、firewalld を起動...