ロックの概念 ①. 現実世界では、鍵は外の世界から身を隠したいときに使う道具です。 ②. コンピュータにおいて、複数のプロセスやスレッドが同時にリソースにアクセスできるように調整する仕組み。 ③ データベースでは、従来のコンピューティングリソース(CPU、RAM、I/Oなど)の競合に加えて、データは多くのユーザーによって共有され、アクセスされるリソースでもあります。 ④. 同時データアクセスの一貫性と有効性をどのように確保するかは、すべてのデータベースが解決しなければならない問題です。 ⑤. ロック競合もデータベースの同時アクセス性能に影響を与える重要な要素です。 MySQL ロックの概要 他のデータベースと比較すると、MySQL のロック メカニズムは比較的単純です。最も注目すべき特徴は、異なるストレージ エンジンが異なるロック メカニズムをサポートしていることです。たとえば、MyISAM および MEMORY ストレージ エンジンはテーブル レベルのロックを使用します。 BDB ストレージ エンジンはページ レベルのロックを使用しますが、テーブル レベルのロックもサポートします。 InnoDB ストレージ エンジンは行レベルのロックとテーブル レベルのロックの両方をサポートしていますが、デフォルトでは行レベルのロックが使用されます。 テーブル レベル ロック: テーブル レベル ロックは、MySQL で最も細かいロックであり、現在の操作のテーブル全体をロックすることを意味します。オーバーヘッドが低く、ロックが高速で、デッドロックは発生せず、ロックの粒度が大きく、ロック競合の可能性が最も高く、同時実行性が最も低くなります。 行レベル ロック: 行レベル ロックは MySQL で最も細かい粒度のロックであり、現在操作中の行のみがロックされます。オーバーヘッドが高く、ロックが遅く、デッドロックが発生する可能性があります。ロックの粒度は最小で、ロック競合の可能性は最低で、同時実行性は最高です。 ページ レベル ロック: ページ レベル ロックは、MySQL のロックの一種で、ロックの粒度は行レベル ロックとテーブル レベル ロックの中間です。テーブルレベルのロックは高速ですが、競合が多く発生します。行レベルの競合は少なくなりますが、速度は遅くなります。したがって、隣接するレコードのグループを一度にロックするために、妥協的なページ レベルが採用されます。 BDB はページレベルのロックをサポートしています。オーバーヘッドとロック時間はテーブル ロックと行ロックの間であり、デッドロックが発生する可能性があります。ロックの粒度はテーブル ロックと行ロックの間であり、同時実行性は平均的です。 上記の特性から、どのロックが優れているかを一概に言うのは難しいことがわかります。特定のアプリケーションの特性に基づいて、どのロックがより適しているかを言うことしかできません。 !ロックの観点からのみ見ると、テーブル レベルのロックは、Web アプリケーションなど、クエリ指向でインデックス条件に基づいて少量のデータのみを更新するアプリケーションに適しています。行レベルのロックは、一部のオンライン トランザクション処理 (OLTP) システムなど、インデックス条件と同時クエリに基づいて少量の異なるデータを大量に同時に更新するアプリケーションに適しています。 例 ①商品を購入する際、在庫が1つしかなく、2人が同時に購入しようとした場合、誰が受け取るのでしょうか? ②. トランザクションを使用して、まず在庫テーブルから商品データを取得し、次に注文を挿入し、支払い後に支払いテーブル情報を挿入します。 ③. 商品の数量を更新します。このプロセスでは、ロックを使用することで限られたリソースを保護し、分離性と同時実行性の矛盾を解決できます。 ロックの分類 操作別:
粒子サイズ別:
上記は、MySQL ロックに関するすべての関連知識ポイントです。123WORDPRESS.COM をお読みいただき、サポートしていただき、ありがとうございます。 以下もご興味があるかもしれません:
|
<<: Linux でファイアウォールがオフになっているかどうかを確認する方法
1. 問題MySQL の初期化時に発生する問題は、次のとおりです。 1. 「MSVCR120.dll...
この記事では、参考までに、計算機のWebバージョンを実装するためのJavaScriptの具体的なコー...
Mysql Workbench はオープンソースのデータベース クライアントです。このオープンソース...
docker-compose で mongodb と mysql を構築する詳細な方法を見てみましょ...
目次序文1. 需要と効果必要効果2. コードの実装index.vue(html)日付方法テスト結果3...
この記事の例では、ショッピングカートの簡単な追加と削除を実現するためのJSの具体的なコードを参考まで...
コードをコピーコードは次のとおりです。 <hr style="width:490px...
1. 子コンポーネントのthis.$parent.eventを通じて親コンポーネントメソッドを直接呼...
夜にMACの電源を入れたところ、突然ルートアカウントがMySQLに正常にログインできなくなったため、...
成果を達成する 実装コードhtml <h1 class="text-light&qu...
これは純粋に CSS のみを使用して作成されたエフェクトです。簡単に言うと、このエフェクトは画像処理...
MySQL では、SQL ステートメント rename table を使用してテーブル名を変更できま...
1行のコマンド docker run -d \ -v /share:/home/vsftpd \ -...
効果:スライドショーが一方向に動く場合、各画像のサイズ、位置、透明度、レベルを変更する必要があります...
1. 要件:データベースのバックアップは、実稼働環境にとって特に重要です。データベースのバックアップ...