Mysql トランザクションで Update を実行するとテーブルがロックされますか?

Mysql トランザクションで Update を実行するとテーブルがロックされますか?

2つのケース:

1. 索引あり 2. 索引なし

前提条件:

方法: コマンドラインを使用してシミュレートする

1. MySQL はデフォルトでトランザクションを自動的にコミットするため、まず現在のデータベースでトランザクションが自動的にコミットされているかどうかを確認する必要があります。

コマンド: select @@autocommit;

結果は次のとおりです。

+--------------+
| @@自動コミット |
+--------------+
| 0 |
+--------------+

1の場合は、コマンドset autocommit = 0;を実行して自動コミットを無効にします。

2. 現在のデータベーステーブル形式は次のとおりです。

tb_user | テーブル `tb_user` を作成する (
 `id` bigint(20) NOT NULL AUTO_INCREMENT,
 `name` varchar(32) デフォルト NULL,
 `phone` varchar(11) デフォルト NULL,
 `operator` varchar(32) デフォルト NULL,
 `gmt_create` 日時 デフォルト NULL、
 `gmt_modified` 日時 デフォルト NULL、
 主キー (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 デフォルト CHARSET=utf8

当然ですが、主キー以外のインデックスは追加していません。

実例:

1. 索引なし

トランザクションを開始するには、begin; コマンドを実行し、変更を加えるには、update tb_user set phone=11 where name="c1"; コマンドを実行します。まだトランザクションをコミットしないでください。

別のウィンドウを開き、コマンドを直接実行します: update tb_user set phone=22 where name="c2"; コマンドが停止していることがわかります。ただし、前のトランザクションがコミットを通じて送信されると、コマンドは正常に実行されて終了し、テーブルがロックされていることが示されます。

2. 名前フィールドにインデックスを追加する

tb_user(name) にインデックス index_name を作成します。

次に、ステップ1と同じように操作を続行します。つまり、トランザクションを開いて、update tb_user set phone=11 where name="c1"; を実行します。まだコミットしないでください。

次に、別のコマンド update tb_user set phone=22 where name="c2"; を実行すると、コマンドがスタックせず、テーブルがロックされていないことがわかります。

しかし、別の update tb_user set phone=22 where name="c1"; が同じ行を更新する場合、その行はロックされていることを意味します。

3. まとめ

インデックスがない場合、更新によってテーブルがロックされます。インデックスが追加されると、行がロックされます。

これで、MySQL トランザクションの更新がテーブルをロックするかどうかについてのこの記事は終わりです。MySQL トランザクションの更新がテーブルをロックするかどうかの詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM を応援してください。

以下もご興味があるかもしれません:
  • MySQL UPDATE ステートメントの非標準実装コード
  • mysql 更新ケース更新フィールド値が固定されていない操作
  • MySQLでレコードを変更する場合、更新操作フィールド = フィールド + 文字列
  • MySQL で結果を選択して更新を実行する例のチュートリアル
  • 複数のフィールドを変更するためのMysql更新の構文の詳細な分析
  • MySQLのUPDATE文の落とし穴を記録する
  • MySQL ジョイントテーブル更新デー​​タの詳細な例
  • mysql update文の実行プロセスの詳細な説明
  • Mysql 更新マルチテーブル共同更新方法の概要
  • MySQL 更新セットとの違い

<<:  Dockerのオンラインおよびオフラインインストールと一般的なコマンド操作

>>:  HTML マークアップ言語 - テーブルタグ

推薦する

Windows ベースの MySQL 8.0.12 のインストール

このチュートリアルは Windows システムにのみ適用されます。インストールしたがまだインストール...

MySQL のユニークインデックスと通常のインデックスのどちらを選択すればよいでしょうか?

ユーザー テーブルを設計するときに、各人の ID 番号が一意であり、検索する必要があるシナリオを想像...

MySQL の where と on の違いと、いつ使用するか

以前、テーブル結合クエリを書いていたとき、whereとonの違いがわからず、SQLに小さな問題が発生...

nginxを使用して取得したIPアドレスが127.0.0.1である問題を解決する

IPツールを取得 lombok.extern.slf4j.Slf4j をインポートします。 org....

デザイン理論:テキスト表現とユーザビリティ

<br />テキストデザインでは、通常、テキストのレイアウト、つまりテキストをより美しく...

RedHat 6.5/CentOS 6.5 に MySQL 5.7.20 をインストールするための詳細なチュートリアル

rpmインストールパッケージをダウンロードするMySQL公式サイト: https://dev.mys...

MySQLの手順を完全に削除する

目次1. まずMySQLサーバーを停止する2. MySQLサーバーをアンインストールする3. MyS...

MySQL 操作: JSON データ型の操作

前回の記事では、MySQL データ保存手順パラメータの詳細な例を紹介しました。今日は、JSON デー...

Mysqlは実行中のトランザクションを照会し、ロックを待機する方法

navicatを使用してテストと学習を行います。まず、 set autocommit = 0;を使用...

非常に便利な CSS 開発ツール 8 つを紹介

CSS3 パターン ギャラリーこの CSS3 パターン ライブラリには、純粋な CSS3 を使用して...

MySQL の CPU 負荷が高い問題のトラブルシューティング

MySQL による CPU 負荷の上昇今日の午後、MySQL によってサーバーの負荷が高くなる問題を...

MySQL 文字列分割の例 (区切り文字なしの文字列抽出)

区切り文字なしの文字列抽出質問の要件データベース内のフィールド値:実装効果: 1行のデータを複数行に...

crontab の実行結果を電子メールでユーザーに通知する方法

症状Centos7 ホストに crontab タスクを設定しましたが、時間が来るとメールを実行して「...

ファイアウォールの iptables 戦略を使用して Linux サーバー上のポートを転送する方法

2つの異なるサーバー間の転送ポート転送を有効にするまず、デフォルトでは無効になっている IP 転送機...

Windows で削除された MySQL 8.0.17 のルート アカウントとパスワードを回復する方法

少し前にSQLの独学を終え、MySQL 8.0.17をダウンロードしました。インストールして設定した...