ホームページ データベース mysql チュートリアル MySQL ロック、トランザクション分離レベル、アプリケーションの関係

MySQL ロック、トランザクション分離レベル、アプリケーションの関係

Dec 21, 2023 am 08:27 AM
応用 mysqlロック トランザクション分離レベル

MySQL 锁的事务隔离级别与应用

MySQL ロックのトランザクション分離レベルとアプリケーション
データベースでは、トランザクション分離レベルは非常に重要な概念であり、同時トランザクション間の分離の程度を決定します。 MySQL は、READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ、SERIALIZABLE の 4 つのトランザクション分離レベルを提供します。トランザクション分離レベルが異なれば、データの読み取りと書き込みに対するロック戦略も異なるため、アプリケーションで適切なトランザクション分離レベルを正しく選択して使用することが重要です。

  1. READ UNCOMMITTED (コミットされていない読み取り): このレベルでは、トランザクションは他のトランザクションからコミットされていないデータを読み取ることができます。これは、ダーティ リード、つまり検証されていないデータが読み取られる可能性があることを意味します。特別な状況下で非常にリアルタイムのデータを取得する必要がある場合を除き、このレベルは通常推奨されません。
  2. READ COMMITTED (コミットされた読み取り): このレベルでは、トランザクションは送信されたデータの読み取りのみが可能です。これにより、ダーティ リードの問題は回避されますが、再現不可能な読み取りの問題が発生する可能性があります。非反復読み取りとは、同じトランザクション内で同じデータを 2 回読み取ることを指しますが、結果に一貫性がありません。これは、トランザクションの実行中に他のトランザクションがデータを更新した可能性があるためです。
  3. REPEATABLE READ (反復可能読み取り): このレベルでは、トランザクションは同じデータを複数回読み取り、一貫した結果を得ることができます。これは、読み取りプロセス中にデータをロックすることによって実現されます。 REPEATABLE READ レベルでは、読み取り操作は条件を満たすデータ行のロックを共有するため、他のトランザクションはデータの読み取りのみが可能ですが、データの変更はできません。ただし、ファントム読み取りの問題が依然として発生する可能性があります。ファントム読み取りとは、同じトランザクション内で範囲内のデータを 2 回読み取ることを指しますが、結果に一貫性がありません。これは、トランザクションの実行中に、他のトランザクションによって条件を満たすデータが挿入または削除された可能性があるためです。
  4. SERIALIZABLE (シリアル化): このレベルでは、トランザクションはシリアルに実行されます。これは、同時に 1 つのトランザクションだけがデータを変更でき、他のトランザクションはロックが解放されるのを待っていることを意味します。このレベルでは、ダーティ読み取り、反復不能読み取り、ファントム読み取りの問題を完全に回避できますが、他のトランザクションがロックを解放するのを待つ必要があるため、同時実行パフォーマンスにも大きな影響を与えます。

以下では、特定のコード例を使用して、さまざまなトランザクション分離レベルでのロック戦略を示します。

最初にテスト テーブルを作成します。

CREATE TABLE test_table (
  id INT PRIMARY KEY,
  name VARCHAR(100),
  age INT
);
ログイン後にコピー

次に、さまざまなトランザクションをそれぞれ示します。分離レベルでのロック戦略:

  1. READ UNCOMMITTED:

    -- 执行事务1
    SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
    START TRANSACTION;
    SELECT * FROM test_table WHERE id = 1;
    
    -- 执行事务2
    START TRANSACTION;
    UPDATE test_table SET age = 20 WHERE id = 1;
    COMMIT;
    
    -- 继续执行事务1
    SELECT * FROM test_table WHERE id = 1;
    COMMIT;
    ログイン後にコピー

    この例では、トランザクション 1 は、トランザクション 2 によって変更されたがコミットされていないデータを読み取ります。

  2. READ COMMITTED:

    -- 执行事务1
    SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
    START TRANSACTION;
    SELECT * FROM test_table WHERE id = 1;
    
    -- 执行事务2
    START TRANSACTION;
    UPDATE test_table SET age = 20 WHERE id = 1;
    COMMIT;
    
    -- 继续执行事务1
    SELECT * FROM test_table WHERE id = 1;
    COMMIT;
    ログイン後にコピー

    この例では、トランザクション 1 はトランザクション 2 が送信したデータのみを読み取ることができます。

  3. REPEATABLE READ:

    -- 执行事务1
    SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
    START TRANSACTION;
    SELECT * FROM test_table WHERE id = 1;
    
    -- 执行事务2
    START TRANSACTION;
    UPDATE test_table SET age = 20 WHERE id = 1;
    COMMIT;
    
    -- 继续执行事务1
    SELECT * FROM test_table WHERE id = 1;
    COMMIT;
    ログイン後にコピー

    この例では、トランザクション 1 はデータの読み取り時に共有ロックを追加し、トランザクション 2 はトランザクション 1 がその前に共有ロックを解放するのを待ちます。実行できます。

  4. SERIALIZABLE:

    -- 执行事务1
    SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
    START TRANSACTION;
    SELECT * FROM test_table WHERE id = 1;
    
    -- 执行事务2
    START TRANSACTION;
    UPDATE test_table SET age = 20 WHERE id = 1;
    COMMIT;
    
    -- 继续执行事务1
    SELECT * FROM test_table WHERE id = 1;
    COMMIT;
    ログイン後にコピー

    この例では、トランザクション 1 はデータの読み取り時に共有ロックを追加し、トランザクション 2 はトランザクション 1 が共有ロックを解放するまで待機します。処刑される。

    上記のコード例を通じて、さまざまなトランザクション分離レベルでロック戦略がどのように機能するかを確認できます。実際のアプリケーション開発では、適切なトランザクション分離レベルを選択することが非常に重要であり、特定のビジネス シナリオやパフォーマンス要件に応じて選択できます。

    以上がMySQL ロック、トランザクション分離レベル、アプリケーションの関係の詳細内容です。詳細については、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)

PHP における矢印記号の役割と実際の応用 PHP における矢印記号の役割と実際の応用 Mar 22, 2024 am 11:30 AM

PHP における矢印記号の役割と実際の応用 PHP では、通常、オブジェクトのプロパティとメソッドにアクセスするために矢印記号 (->) が使用されます。オブジェクトとは、PHP におけるオブジェクト指向プログラミング (OOP) の基本概念の 1 つで、実際の開発においては、矢印記号がオブジェクトを操作する上で重要な役割を果たします。この記事では、矢印記号の役割と実際の応用例を紹介し、読者の理解を深めるために具体的なコード例を示します。 1. オブジェクトのプロパティにアクセスするための矢印シンボルの役割 矢印シンボルは、オブジェクトのプロパティにアクセスするために使用できます。ペアをインスタンス化するとき

iPhoneのホーム画面から削除を元に戻す方法 iPhoneのホーム画面から削除を元に戻す方法 Apr 17, 2024 pm 07:37 PM

ホーム画面から重要なものを削除してしまい、元に戻そうとしていますか?さまざまな方法でアプリのアイコンを画面に戻すことができます。 iPhoneでホーム画面から削除を元に戻す方法 前述したように、iPhoneでこの変更を復元する方法はいくつかあります。方法 1 – App ライブラリのアプリ アイコンを置き換える App ライブラリから直接ホーム画面にアプリ アイコンを配置できます。ステップ 1 – 横にスワイプして、アプリ ライブラリ内のすべてのアプリを見つけます。ステップ 2 – 前に削除したアプリのアイコンを見つけます。ステップ 3 – アプリのアイコンをメインライブラリからホーム画面上の正しい場所にドラッグするだけです。これが応用図です

初心者から熟練者まで: Linux tee コマンドのさまざまなアプリケーション シナリオを探索する 初心者から熟練者まで: Linux tee コマンドのさまざまなアプリケーション シナリオを探索する Mar 20, 2024 am 10:00 AM

Linuxtee コマンドは、既存の出力に影響を与えることなく、出力をファイルに書き込んだり、別のコマンドに出力を送信したりできる、非常に便利なコマンド ライン ツールです。この記事では、入門から習熟まで、Linuxtee コマンドのさまざまな応用シナリオを詳しく見ていきます。 1. 基本的な使い方 まずは、teeコマンドの基本的な使い方を見てみましょう。 tee コマンドの構文は次のとおりです。 tee[OPTION]...[FILE]...このコマンドは、標準入力からデータを読み取り、データを保存します。

Go 言語の利点と応用シナリオを探る Go 言語の利点と応用シナリオを探る Mar 27, 2024 pm 03:48 PM

Go 言語は、Google によって開発され、2007 年に初めてリリースされたオープンソース プログラミング言語です。シンプルで習得しやすく、効率的で同時実行性の高い言語となるように設計されており、ますます多くの開発者に好まれています。この記事では、Go 言語の利点を探り、Go 言語に適したいくつかのアプリケーション シナリオを紹介し、具体的なコード例を示します。利点: 強力な同時実行性: Go 言語には、同時プログラミングを簡単に実装できる軽量スレッドのゴルーチンのサポートが組み込まれています。 Goroutin は go キーワードを使用して開始できます

クラウドコンピューティング分野におけるLinuxの幅広い応用 クラウドコンピューティング分野におけるLinuxの幅広い応用 Mar 20, 2024 pm 04:51 PM

クラウド コンピューティングの分野における Linux の幅広い応用 クラウド コンピューティング テクノロジの継続的な開発と普及に伴い、オープン ソース オペレーティング システムとしての Linux はクラウド コンピューティングの分野で重要な役割を果たしています。 Linux システムは、その安定性、セキュリティ、柔軟性により、さまざまなクラウド コンピューティング プラットフォームやサービスで広く使用されており、クラウド コンピューティング テクノロジーの開発に強固な基盤を提供しています。この記事では、クラウド コンピューティング分野における Linux の幅広いアプリケーションを紹介し、具体的なコード例を示します。 1. クラウドコンピューティングプラットフォームにおけるLinuxのアプリケーション仮想化技術 仮想化技術

Golang スタック管理の仕組みと応用を理解する Golang スタック管理の仕組みと応用を理解する Mar 13, 2024 am 11:21 AM

Golang は、Google が開発したオープンソース プログラミング言語で、同時プログラミングとメモリ管理において多くの独自の機能を備えています。その中でも、Golang のスタック管理の仕組みは重要な機能であり、本記事では Golang のスタック管理の仕組みと応用例に焦点を当て、具体的なコード例を示します。 1. Golang でのスタック管理 Golang では、各 goroutine が独自のスタックを持ちます。スタックは、パラメータ、ローカル変数、関数呼び出しの関数戻りアドレスなどの情報を格納するために使用されます。

MySQL タイムスタンプを理解する: 機能、特徴、およびアプリケーション シナリオ MySQL タイムスタンプを理解する: 機能、特徴、およびアプリケーション シナリオ Mar 15, 2024 pm 04:36 PM

MySQL タイムスタンプは、日付、時刻、または日付と時刻を格納できる非常に重要なデータ型です。実際の開発プロセスでは、タイムスタンプを合理的に使用すると、データベース操作の効率が向上し、時間関連のクエリと計算が容易になります。この記事では、MySQL タイムスタンプの機能、特徴、および適用シナリオについて説明し、具体的なコード例を示して説明します。 1. MySQL タイムスタンプの機能と特徴 MySQL には 2 種類のタイムスタンプがあり、1 つは TIMESTAMP です。

実行中のアプリを終了する方法に関する Apple のチュートリアル 実行中のアプリを終了する方法に関する Apple のチュートリアル Mar 22, 2024 pm 10:00 PM

1. まず、小さな白い点をクリックします。 2. デバイスをクリックします。 3. 「詳細」をクリックします。 4. 「アプリケーションスイッチャー」をクリックします。 5. アプリケーションのバックグラウンドを閉じます。

See all articles