ページ分割されたクエリを実行するには: 1. MySQL の場合、サブクエリと結合の使用は推奨されません。結合の効率に欠陥があるためです。データ量が多くなると、効率を保証することが難しくなります。インデックスに基づいて単一のテーブルからデータを取得し、プログラム内でデータを結合してマージすることを強くお勧めします。 1. アプリケーション層アソシエーションの利点キャッシュをより効率的にします。多くのアプリケーションでは、単一テーブル クエリに対応する結果オブジェクトを簡単にキャッシュできます。関連付け内のテーブルが変更されると、クエリ キャッシュは使用できません。分割後、テーブルがほとんど変更されない場合は、テーブルに基づくクエリでクエリ キャッシュの結果を再利用できます。 クエリを個々の部分に分割すると、ロックの競合を減らすことができます。 アプリケーション層で関連付けを行うことで、データベースを分割し、高いパフォーマンスとスケーラビリティを実現しやすくなります。 クエリ自体の効率も向上する可能性があります。 ID セットをクエリする場合、結合クエリの代わりに IN() を使用すると、MySQL は ID の順序でクエリを実行できるため、ランダム結合よりも効率的になる可能性があります。 これにより、冗長なレコードクエリの数を減らすことができます。アプリケーション層で連想クエリを実行すると、アプリケーションは特定のレコードを一度だけクエリすればよいが、データベースで連想クエリを実行すると、 データの一部に繰り返しアクセスすること。この観点から見ると、このような再構築により、ネットワークとメモリの消費も削減される可能性があります。 さらに、これは MySQL のネストされたループ結合を使用するのではなく、アプリケーションでハッシュ結合を実装することと同じです。シナリオによっては、ハッシュ関連付けの方がはるかに効率的です。 2. アプリケーション層アソシエーションの使用シナリオアプリケーションが単一のクエリの結果を便利にキャッシュできる場合 異なるMySQLサーバー間でデータを分散できる場合 IN() を結合クエリの代わりに使用できる場合 同時実行シナリオが多く、DBクエリが頻繁に発生するため、シャーディングが必要です。 3. 参加が推奨されない理由1. DB は大きなビジネス上のプレッシャーにさらされており、その負担をできるだけ軽減したいと考えています。テーブルに 100 万ページ以上ある場合、結合によってパフォーマンスが低下します。 4. 結合なしのソリューションビジネス レイヤーでは、単一のテーブルに対してデータのクエリが実行された後、そのデータが次の単一テーブル クエリの条件として使用されます。つまり、サブクエリです。サブクエリからの結果セットが多すぎるのではないかと心配です。 MySQL では IN の数に制限はありませんが、SQL ステートメント全体のサイズは制限されます。パラメータ max_allowed_packet を調整することで、SQL ステートメントの最大値を変更できます。ビジネスを適切に処理し、単一のクエリの結果セットを許容できる範囲に制限することをお勧めします。 5. 結合クエリの利点関連クエリの利点は、ページ付けが可能で、セカンダリ テーブルのフィールドをクエリ条件として使用できることです。クエリを実行すると、セカンダリ テーブルに一致するフィールドが結果セットとして使用され、プライマリ テーブルがその中で使用されるようになります。しかし、問題は、一致するデータの量が多すぎると機能せず、返されるページング レコードが実際のものと異なることです。解決策としては、フロント エンドに 1 回限りのクエリを渡して、フロント エンドでバッチで表示させることができます。この解決策の前提は、SQL 自体の長さが制限されているため、データの量が大きすぎないことです。 これで、MySQL がサブクエリと結合の使用を推奨しない理由に関するこの記事は終了です。関連する MySQL サブクエリと結合の詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
テーブルの背景色は、BGCOLOR 属性を通じて設定できます。基本的な構文<テーブル BGCO...
Tomcatをインストールする前に、まずJDK環境をインストールしてくださいLinux サーバー上で...
ファイルをディレクトリに解凍しますこれは解凍後のディレクトリですmy.iniファイルを入力しますダブ...
この記事では、全選択と逆選択操作を実装するためのjQueryの具体的なコードを参考までに共有します。...
目次背景なぜエラー処理が必要なのでしょうか? async await より適切なエラー処理まとめ要約...
目次前面に書かれたルータ.jsonルート生成メニュー生成効果要約する前面に書かれたルートを繰り返し記...
最近、hadoop テスト クラスターで spark ストリーミング プログラムを実行し、その後、n...
序文最近、私はクライアントのサーバー構成を支援しており、Nginx 構成ファイルを頻繁に変更していま...
1. リポジトリイメージをダウンロードする docker プルレジストリ 2. プライベートウェアハ...
CSS命名規則 ヘッダー: ヘッダーコンテンツ: コンテンツ/含むフッターナビゲーション: navサ...
大画面のデジタル スクロール効果は、最近の作業における大画面 UI ダイアグラムから生まれました。U...
この記事では、淘宝虫眼鏡効果を実現するためのJavaScriptの具体的なコードを参考までに紹介しま...
弊社の Web プロジェクトの 1 つでは、新しい都市の増加によりトラフィックと DB 負荷が増加し...
相対パスの概念現在のファイルの場所を参照ポイントとして使用して、ターゲット ファイルへのパスを確立し...
目次1. はじめに2. コンポーネント開発1. コンポーネントの構成2. ヘッダーコンポーネントの開...