ウィンドウ集計関数の論理読み取りが高くなる理由
実行プランで共通の部分式スプールを利用すると、論理読み取りが大幅に増加する傾向があります大きなテーブル用。実行計画を実験して観察した結果、次の式が成り立つことが判明しました:
ワークテーブルの論理読み取り = 1 NumberOfRows 2 NumberOfGroups 4
しかし、この公式の根本的な理由は依然として不明です。この記事は、この論理読み取り計算の背後にある謎を解明することを目的としています。
ウィンドウ集計関数の実行について
プランの最初のセグメント反復子は、行にフラグを追加します。それぞれの新しいパーティションの開始を示します。その後、プライマリ セグメント スプールは一度に 1 行ずつ行を取得し、それらを tempdb 作業テーブルに挿入します。新しいグループ フラグを検出すると、スプールはネストされたループ演算子の上部入力に行を返します。
これにより、作業テーブルの行に対するストリームの集計がトリガーされ、平均が計算されます。次に、計算された平均が作業テーブルの行と結合され、次のグループに備えて作業テーブルが切り詰められます。セグメント スプールは、最後のグループを処理するためにダミー行を生成します。
ワークテーブルの論理読み取り計算
私たちの理解によれば、ワークテーブルはヒープ (またはインデックス スプール)計画に別途指定がある場合)。この例では、予想に反して、11 回の論理読み取りのみが必要です。この違いの説明は次のとおりです。
- ワークテーブルへの行の挿入はそれぞれ 1 つの論理読み取りを考慮し、結果として 3 つの論理読み取りが行われます。
- 平均の計算には 1 つの論理読み取りが含まれます。合計 4 つの読み取りが行われます。
- 平均列を含む行を返すには、4 つの論理演算が必要です
- ワークテーブルを切り詰めると、論理読み取りは発生しません。
これにより、論理読み取りの合計は 4 x 3 = 12 になり、論理読み取りをトリガーする 4 行目の挿入が省略されます。オリジナルでのみシナリオ。
結論
この式を理解するための鍵は、ワークテーブルと通常のスプール テーブルの論理読み取りカウント間の不一致にあります。ワークテーブルの場合、読み取られた各行は 1 回の論理読み取りとしてカウントされますが、スプール テーブルの場合は、ハッシュされた各ページがカウントされます。
式は観察された実行と一致しています。2 つのセカンダリ スプールが 2 回読み取られます (2 COUNT) ())、プライマリ スプールは、次のブログ エントリで説明されているように (COUNT(DISTINCT CustomerID) 1) 行を出力します。追加情報。追加の行は、最後のグループの終わりを示すために発行された追加の行によるものです。
以上がSQL Server でウィンドウ集計関数によってこのような大量の論理読み取りが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

mysqlhandlesconcurrencyusing amixofrow-levelandtable-levellocking、主にthroughnodb'srow-levellocking.comparedtootherrdbms、mysqlのsapproachiseformanyusecasesecasesbutmayfaceChallengeswithdeadlockdlacklikeRisikErisikErikErikErikErikErikErikErikErikErikErikErikErikErikErikeを使用してください

mysqlhandlestransactionsefectivectivelivationtivelivational supportingingacidpropertiessimilArtopostgreslesclandoracle.1)mysqluseSesrepeatable-readededededededededededefaultisolation level

mysqlisbetterforspeedandsimplicity、適切なforwebapplications; postgresqlexcelsincomplexdatascenararios withobustfeatures.mysqlisidealforquickprojectsandread-havytasks、whilepostgressqlessqlispreredforforivationsRedictrictiontrictdateinitegriTinitegriTiontegriTioniitaintegrategrisioniationegrisioniaty

MySQLは、非同期、半同期、およびグループ複製の3つのモードを介してデータの複製を処理します。 1)非同期の複製パフォーマンスは高くなりますが、データが失われる可能性があります。 2)半同期複製により、データセキュリティが向上しますが、遅延が増加します。 3)グループレプリケーションは、高可用性要件に適したマルチマスターレプリケーションとフェールオーバーをサポートします。

説明ステートメントは、SQLクエリのパフォーマンスを分析および改善するために使用できます。 1.説明ステートメントを実行して、クエリプランを表示します。 2。出力結果を分析し、アクセスの種類、インデックスの使用量に注意し、順序を結合します。 3.分析結果に基づいてインデックスを作成または調整し、結合操作を最適化し、フルテーブルスキャンを回避してクエリ効率を向上させます。

論理バックアップにMySQLDUMPとホットバックアップにMySQLenterPriseBackupを使用することは、MySQLデータベースをバックアップする効果的な方法です。 1. mysqldumpを使用してデータベースをバックアップします:mysqldump-uroot-pmydatabase> mydatabase_backup.sql。 2。ホットバックアップにmysqlenterprisebackupを使用:mysqlbackup - user = root-password = password - backup-dir =/path/to/backupbackup。回復するときは、対応する寿命を使用します

MySQLのクエリが遅い主な理由には、インデックスの欠落または不適切な使用、クエリの複雑さ、過剰なデータボリューム、および不十分なハードウェアリソースが含まれます。最適化の提案には以下が含まれます。1。適切なインデックスを作成します。 2。クエリステートメントを最適化します。 3.テーブルパーティションテクノロジーを使用します。 4.適切にハードウェアをアップグレードします。

MySQLビューは、SQLクエリの結果に基づいた仮想テーブルであり、データを保存しません。 1)ビューは複雑なクエリを簡素化し、2)データセキュリティを強化し、3)データの一貫性を維持します。ビューは、テーブルのように使用できるデータベースにクエリを保存しますが、データは動的に生成されます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール

WebStorm Mac版
便利なJavaScript開発ツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ホットトピック









