ホームページ データベース mysql チュートリアル 悲観的ロックと楽観的ロックの簡単な説明

悲観的ロックと楽観的ロックの簡単な説明

Sep 05, 2019 pm 04:00 PM
悲観的なロック

悲観的ロックは、名前が示すとおり、非常に悲観的です。データを取得しに行くたびに、他の人がそのデータを変更すると考えて、データを取得するたびにロックします。 , そのため、他の人がこのデータを取得すると、ロックが取得されるまでブロックされます。このようなロック メカニズムの多くは、行ロック、テーブル ロック、読み取りロック、書き込みロックなど、従来のリレーショナル データベースで使用されており、操作前にすべてロックされます。

悲観的ロックと楽観的ロックの簡単な説明

最も一般的に使用されるのは select... for update です。これは、トランザクションがコミットまたはロールバックされる前に選択の結果行をロックする行ロックです。他のトランザクションは、これらの行に対して更新、削除、または更新操作を実行することはできません。

楽観的ロック, 名前が示すように、非常に楽観的で、データを取得するたびに、他の人がデータを変更しないと考えてロックされません。この期間中はデータを自由に利用することができ、他の人に読み込まれますが、更新する際にはこの期間内に他の人がデータを更新したかどうかを判断し、バージョン番号などの仕組みを利用することができます。

バージョン番号メカニズムは、オプティミスティック ロックの最も一般的に使用される方法です。これは、テーブルにバージョン番号フィールドを追加することです。更新する前に、それを確認してバージョン番号を取得し、それを where として更新します。 update文の条件 Javaバックグラウンドで取得した更新番号の場合、バージョン番号取得後、更新前にデータが変更されている場合、最終的に更新されたデータは0個のため更新に失敗します。が 0 の場合は、更新が失敗し、同時実行の問題が発生したことを意味します。その後、具体的な対処を行ってください。

たとえば、2 人が同時に特定のデータを変更すると、プロセスは次のようになります:

オペレーター A は次のように動作します:

select id, balance, version from table where id=“1”;
ログイン後にコピー
ログイン後にコピー

クエリ結果: id=1, Balance=1000 , version=1

update table set balance=balance+100, version=version+1 where id=“1” and version=1;
ログイン後にコピー

実行後、返された更新結果は 1 で、1 つのアイテムが更新されたことを示します。データベース内の結果は次のようになります: id=1, Balance=1100 、version=2

操作 オペレーター B は次のように動作します:

select id, balance, version from table where id=“1”;
ログイン後にコピー
ログイン後にコピー

クエリ結果: id=1、balance=1000、version=1、オペレーター A がまだ変更していないことを示します。

update table set balance=balance-50, version=version+1 where id=“1” and version=1 ;
ログイン後にコピー

確認すると、オペレーター A はまだ変更していません。更新するときは、オペレーター A が先に変更に成功しているため、データベース内の実際の値は id=1、balance=1100 になります。 、version=2,

オペレータ B もバージョン番号を 1 つインクリメントし (version=2)、データベースにデータを送信しようとします (balance=950) が、この時点では id=1 のデータは送信されません。 " および version=1 が見つかりません。

したがって、更新は失敗し、実行結果は 0 となり、データが正常に更新されなかったことを示します。

ここでもう一度確認してください。結果は、オペレーター A が操作を完了した後の結果のままです。

select id, Balance, version from table where id="1";

Query結果: id=1、balance=1100、version=2

以上がバージョン番号の仕組みを自分で実装する原理ですが、実際に使用するバージョン番号の仕組みはデータベース自体が提供する仕組みです。更新されたバージョン番号が最新でないことが判明した場合、最新のものは拒否されます。

以上が悲観的ロックと楽観的ロックの簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Mar 19, 2025 pm 03:51 PM

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

INNODBフルテキスト検索機能を説明します。 INNODBフルテキスト検索機能を説明します。 Apr 02, 2025 pm 06:09 PM

INNODBのフルテキスト検索機能は非常に強力であり、データベースクエリの効率と大量のテキストデータを処理する能力を大幅に改善できます。 1)INNODBは、倒立インデックスを介してフルテキスト検索を実装し、基本的および高度な検索クエリをサポートします。 2)一致を使用してキーワードを使用して、ブールモードとフレーズ検索を検索、サポートします。 3)最適化方法には、単語セグメンテーションテクノロジーの使用、インデックスの定期的な再構築、およびパフォーマンスと精度を改善するためのキャッシュサイズの調整が含まれます。

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? Mar 18, 2025 pm 12:01 PM

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? 人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? Mar 21, 2025 pm 06:28 PM

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]

MySQLの大きなデータセットをどのように処理しますか? MySQLの大きなデータセットをどのように処理しますか? Mar 21, 2025 pm 12:15 PM

記事では、MySQLで大規模なデータセットを処理するための戦略について説明します。これには、パーティション化、シャード、インデックス作成、クエリ最適化などがあります。

ドロップテーブルステートメントを使用してMySQLにテーブルをドロップするにはどうすればよいですか? ドロップテーブルステートメントを使用してMySQLにテーブルをドロップするにはどうすればよいですか? Mar 19, 2025 pm 03:52 PM

この記事では、ドロップテーブルステートメントを使用してMySQLのドロップテーブルについて説明し、予防策とリスクを強調しています。これは、バックアップなしでアクションが不可逆的であることを強調し、回復方法と潜在的な生産環境の危険を詳述しています。

JSON列にインデックスを作成するにはどうすればよいですか? JSON列にインデックスを作成するにはどうすればよいですか? Mar 21, 2025 pm 12:13 PM

この記事では、クエリパフォーマンスを強化するために、PostgreSQL、MySQL、MongoDBなどのさまざまなデータベースでJSON列にインデックスの作成について説明します。特定のJSONパスのインデックス作成の構文と利点を説明し、サポートされているデータベースシステムをリストします。

さまざまなタイプのMySQLインデックス(Bツリー、ハッシュ、フルテキスト、空間)を説明します。 さまざまなタイプのMySQLインデックス(Bツリー、ハッシュ、フルテキスト、空間)を説明します。 Apr 02, 2025 pm 07:05 PM

MySQLは、Bツリー、ハッシュ、フルテキスト、および空間の4つのインデックスタイプをサポートしています。 1.B-Treeインデックスは、等しい値検索、範囲クエリ、ソートに適しています。 2。ハッシュインデックスは、等しい値検索に適していますが、範囲のクエリとソートをサポートしていません。 3.フルテキストインデックスは、フルテキスト検索に使用され、大量のテキストデータの処理に適しています。 4.空間インデックスは、地理空間データクエリに使用され、GISアプリケーションに適しています。

See all articles