UPDATE はロックしますか? 以下のような場合、SQL文はロックされますか? テーブル1を更新します。SET num = num + 1 WHERE id=1; 答えはノーだ 実際、MySQL はデータ行のロック (InnoDB) をサポートしており、UPDATE/DELETE 操作中に排他ロックを自動的に追加します。ただし、 UPDATE キーワードがある限り、すべてのロックが適用されるわけではありません。 上記の MySQL ステートメントの場合、1 つの UPDATE ステートメントではなく、2 つの SQL ステートメント (疑似コード) に類似している必要があります。 a = SELECT * FROM table1 WHERE id=1; テーブル1を更新します。SET num = a.num + 1 WHERE id=1; SELECT ステートメントを実行するときにはロックはなく、UPDATE を実行するときにのみロックされます。そのため、同時操作中に更新データの不整合が発生します。原因が見つかれば、問題の解決はそう遠くありません。この種の問題を解決するには 2 つの方法があります。
明示的に選択する SELECT をロックする方法は次の 2 つあります。 SELECT ... LOCK IN SHARE MODE #共有ロック、他のトランザクションは読み取り可能だが更新不可 SELECT ... FOR UPDATE #排他ロック、他のトランザクションは読み取りも書き込みも不可 これら 2 つのステートメントを使用しない場合、SELECT ステートメントはデフォルトでロックされません。また、上記のシナリオでは、排他ロックを使用する必要があります。また、上記の 2 つのステートメントはトランザクション内でのみ有効であり、それ以外の場合は有効になりません。 MySQL コマンドラインでトランザクションを使用する方法は次のとおりです。 AUTOCOMMIT=0 を設定します。 作業を開始します。 a = SELECT num FROM table1 WHERE id=2 FOR UPDATE; テーブル1を更新します。SET num = a.num + 1 WHERE id=2; 仕事をコミットする。 このように、将来データを更新するたびに、このトランザクションを使用して操作を実行します。同時実行の場合は、後で実行されるトランザクションは、現在のトランザクションが完了するまでブロックされます。 (ロックにより並行性が順次実行に変更されます) 楽観的ロックの使用 楽観的ロックは、変更する必要があるすべてのデータが競合しないことを単純に想定したロック実装のメカニズムです。したがって、更新前にデータをロックするのではなく、データ行のバージョン番号のみを照会します (ここでのバージョン番号はカスタム フィールドであり、ビジネス テーブルに基づいて追加フィールドを追加する必要があり、更新されるたびに自動的に増加または更新されます)。 データを更新する場合、更新条件にバージョン番号情報が追加されます。
練習する 学生テーブルに1回更新ロックをかける練習をする。学生テーブルには1つのデータがある。 2つのクライアントを開く 最初のオープントランザクションの後に実行される 更新のために、ID = 1 の学生から名前を選択します。 2 番目のトランザクションが開かれた後、同じステートメントが実行され、データが最初のトランザクションによってブロックされていることがわかります。 この時点で、最初のトランザクションが変更を実行してコミットします。 2番目のトランザクションの選択実行が4秒以上ブロックされていることが判明しました まとめ 一般に、どちらの方法でもデータベースでの同時更新操作をサポートできます。ただし、どちらを使用するかは実際のアプリケーション シナリオによって異なり、アプリケーション シナリオでどちらがより適切にサポートされ、パフォーマンスへの影響が最も少ないかによって異なります。 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: MongoDB データベースの状態を監視する Zabbix3.4 メソッド
>>: Ant Design Blazor コンポーネントライブラリのルーティング再利用マルチタブ機能
1. Dockerfileを書く(1)プロジェクト名を右クリックして新しいテキストファイルを作成し、...
ストアドプロシージャ1. ストアドプロシージャを作成し、グローバル変数を表示する mysql>...
1. 前提条件何度かインストールしているので、エラーについてはこれ以上説明しません。ちょっとわかりに...
Webページを作るときに、区切り線hrを使うことがありますが、IE6やIE7で表示するのは非常に苦痛...
MySQL クエリ結果の行フィールドの結合は、次の 2 つの関数を使用して実装できます。 1. co...
1. まず、移行サーバー上のデータ ファイルを見つけます。MySQL 5.7 とデフォルトのインスト...
GitHubアドレス、気に入ったらスターを付けてくださいプラグインのプレビューチュートリアル1. プ...
この記事では、例を使用して、MySQL トリガーの概要、トリガーの作成方法、およびトリガーの使用上の...
目次1. ReactとAntdを組み合わせてログイン機能を実現2. ReactとAntdを組み合わせ...
目次チュートリアルシリーズ1. SQL言語の紹介と仕様2. データベース操作1. ライブラリを作成す...
パート0 背景社内のイントラネットサーバーは直接インターネットにアクセスすることはできませんが、外部...
計算機の主な機能は数値計算を実行することです。計算機機能の Web インスタンスを開発すると、js ...
基本イメージが以前に構成されていて、これらのイメージが他の場所でも必要な場合はどうなりますか?回答:...
conda アップデート conda pip で tf-nightly-gpu-2.0-previ...
ボタンをクリックしてテキストを入力ボックスに変換し、保存をクリックしてテキスト実装コードに変換します...