MySQL の行レベルロックの詳細な例

MySQL の行レベルロックの詳細な例

序文

ロックは、複数のスレッドを実行するときにリソースへのアクセスを強制的に制限するために使用される同期メカニズムです。データベース ロックは、ロックの粒度に応じて、行レベル ロック、テーブル レベル ロック、ページ レベル ロックに分類できます。

行レベルロック

行レベル ロックは、MySQL で最も粒度の細かいロック メカニズムです。つまり、現在操作されている行のみがロックされます。行レベル ロックの競合の可能性は非常に低く、粒度も最も小さいですが、ロックのコストは最も高くなります。行レベル ロックは、共有ロックと排他ロックに分けられます。

特徴:

オーバーヘッドが高く、ロックが遅く、デッドロックが発生する可能性があります。ロックの粒度が小さく、ロックの競合の可能性が最も高く、同時実行性も高くなります。

実施原則:

InnoDB の行ロックは、インデックス項目をロックすることによって実装されます。これは、MySQL や Oracle とは異なります。後者は、データベース内の対応するデータ行をロックすることによって実装されます。InnoDB の行レベル ロックでは、行レベル ロックはインデックス条件を通じてデータを取得する場合にのみ使用できます。それ以外の場合は、テーブル レベルのロックが直接使用されます。特記事項: 行レベルロックを使用する場合は、インデックスを使用する必要があります

例えば:

テーブル構造を作成する

テーブル「developerinfo」を作成します(
 `userID` bigint(20) NULLではない、
 `name` varchar(255) デフォルト NULL,
 `passWord` varchar(255) デフォルト NULL,
 主キー (`userID`)、
 キー `PASSWORD_INDEX` (`passWord`) BTREE の使用
)ENGINE=InnoDB デフォルト文字セット=utf8;

データの挿入

`developerinfo` に VALUES ('1', 'liujie', '123456') を挿入します。
`developerinfo` に VALUES ('2', 'yitong', '123') を挿入します。
`developerinfo` に VALUES ('3', 'tong', '123456') を挿入します。

(1)主キーインデックスを使用してデータベースを照会し、行ロックを使用する

テスト用に3つのコマンドラインウィンドウを開く

コマンドラインウィンドウ 1コマンドラインウィンドウ 2コマンドラインウィンドウ 3

mysql> 自動コミットを 0 に設定します。
クエリは正常です。影響を受けた行は 0 行です
mysql> userid = '1' の場合、developerinfo から * を選択して更新します。
+--------+--------+----------+
| ユーザーID | 名前 | パスワード |
+--------+--------+----------+
| 1 | liujie | 123456 |
+--------+--------+----------+
セット内の1行 
|mysql> 自動コミットを 0 に設定します。
クエリは正常です。影響を受けた行は 0 行です
mysql> userid = '1' の場合、developerinfo から * を選択して更新します。
wait|mysql> 自動コミットを 0 に設定します。
クエリは正常です。影響を受けた行は 0 行です
mysql> userid = '3' で developerinfo から * を選択して更新します。
+--------+------+----------+
| ユーザーID | 名前 | パスワード |
+--------+------+----------+
| 3 | トング | 123456 |
+--------+------+----------+
セット内の1行
|mysql> コミット;
クエリは正常です。影響を受けた行は 0 行です。mysql> select * from developerinfo where userid = '1' for update;
+--------+--------+----------+
| ユーザーID | 名前 | パスワード |
+--------+--------+----------+
| 1 | liujie | 123456 |
+--------+--------+----------+
セット内の1行

(2)行ロックを使用してデータベースを照会するためにインデックスのないフィールドを照会する

テスト用に2つのコマンドラインウィンドウを開きます

コマンドラインウィンドウ 1コマンドラインウィンドウ 2

|mysql> 自動コミットを 0 に設定します。
クエリは正常です。影響を受けた行は 0 行です
mysql> select * from developerinfo where name = 'liujie' for update;
+--------+--------+----------+
ユーザーID 名前 パスワード
+--------+--------+----------+
1 六十六 123456
+--------+--------+----------+
セット内の 1 行 |mysql> set autocommit=0;
クエリは正常です。影響を受けた行は 0 行です
mysql> select * from developerinfo where name = 'tong' for update;
待ってください|
mysql> コミット;
クエリは正常です。影響を受けた行は 0 行です。mysql> select * from developerinfo where name = 'liujie' for update;
+--------+--------+----------+
| ユーザーID | 名前 | パスワード |
+--------+--------+----------+
| 1 | liujie | 123456 |
+--------+--------+----------+
セット内の1行

##### (3) 非一意のインデックスフィールドを使用してデータベースをクエリし、行ロックを使用して複数の行をロックする

MySQL の行ロックはレコードではなくインデックスの疑似ロックなので、異なるレコードがロックされる可能性があります。

テスト用に3つのコマンドラインウィンドウを開く

コマンドラインウィンドウ 1 コマンドラインウィンドウ 2 コマンドラインウィンドウ 3

mysql> 自動コミットを 0 に設定します。
クエリは正常です。影響を受けた行は 0 行です
mysql> developerinfo から * を選択します。パスワード = '123456
' 更新用;
+--------+--------+----------+
| ユーザーID | 名前 | パスワード |
+--------+--------+----------+
| 1 | liujie | 123456 |
| 3 | トング | 123456 |
+--------+--------+----------+
2 行目: set mysql> set autocommit =0;
クエリは正常です。影響を受けた行は 0 行です
mysql> userid = '1' の場合、developerinfo から * を選択して更新します。

待って

mysql> 自動コミットを 0 に設定します。
クエリは正常です。影響を受けた行は 0 行です
mysql> userid = '2 の developerinfo から * を選択します
' 更新用;
+--------+--------+----------+
| ユーザーID | 名前 | パスワード |
+--------+--------+----------+
| 2 | イートン | 123 |
+--------+--------+----------+
セット内の1行
コミット; mysql> select * from developerinfo where userid = '1' for update;
+--------+--------+----------+
| ユーザーID | 名前 | パスワード |
+--------+--------+----------+
| 1 | liujie | 123456 |
+--------+--------+----------+
セット内の1行

##### (4) データベース検索を実行する条件でインデックスを使用する場合、MySQL はさまざまな実行プランを判断してインデックスを使用するかどうかを決定する必要があります。explain を使用してインデックスを判断する方法を決定する必要がある場合は、次の分析を聞いてください。

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。

以下もご興味があるかもしれません:
  • MySQLデッドロック問題の詳細な分析
  • MySql のインデックス、ロック、トランザクションの知識ポイントのまとめ
  • MySQLの共有ロックと排他ロックの使用例の分析
  • MySQLのグローバルロックとテーブルロックに関する詳細な理解
  • MySQL ロックの知識ポイントのまとめ

<<:  Vue を使用した Amap アプリケーション開発のベスト プラクティス

>>:  Win10 に Tomcat サーバーをインストールし、環境変数を構成する詳細なチュートリアル (画像とテキスト)

推薦する

CentOS 7でsambaを使用してフォルダーを共有するための完全な手順

序文Samba は、サーバー プログラムとクライアント プログラムで構成され、Linux システム上...

LinuxとGNUシステムの関係の詳細な説明

目次私たちが毎日実行している Linux システムとは何でしょうか? LinuxカーネルとGNUシス...

CentOS 上での MySQL 5.6 のコンパイルとインストール、および複数の MySQL インスタンスのインストールの詳細な説明

--1. mysql用の新しいグループとユーザーを作成する # ユーザー追加 -M -s /sbin...

Angularの親子コンポーネント通信の詳細な説明

目次概要1. 入力および出力プロパティの概要2. 入力属性3. プロパティバインディングは親コンポー...

MySQLの文字列インターセプト関連関数の概要

この記事では、MySQL の文字列インターセプト関連の機能を紹介します。具体的な内容は以下のとおりで...

JSは単純なフィルタリングから複数条件のフィルタリングまで配列フィルタリングを実装します

目次単一条件単一データフィルタリング単一条件複数データフィルタリング複数の条件付きデータフィルタリン...

Linux アカウントのパスワードを変更する詳細な例

個人アカウントのパスワードを変更する一般ユーザーが個人アカウントのパスワードを変更する場合は、他のコ...

mysql 8.0.19 win10 クイックインストールチュートリアル

このチュートリアルでは、参考までにMySQL 8.0.19のインストールチュートリアルを共有します。...

MySQLの外部結合と内部結合クエリの違い

外部結合の構文は次のとおりです。フィールド名を選択FROM テーブル名 1 LEFT|RIGHT|F...

HTML でナンバープレート番号と州の略語を入力するためのサンプルコード

原理としては、まずボタン付きの div を記述し、次に画面のサイズに応じて自動的に適応してキーボード...

MySQLのクラスタモードでのgalera-clusterのデプロイメントの詳細説明

目次1: galera-clusterの紹介2. galera-clusterの仕組み3: Mari...

Centos7環境でYUMを構築する方法

1. yumソースの設定ファイルを入力します 2.lsで設定ファイルを表示する 3. ディレクトリを...

Ajax の JavaScript ソリューションにおける parsererror エラー ケースの詳細な説明

ajax の parsererror エラー (バックグラウンドからフロントエンドに送信される js...

vue3+electron12+dll 開発のためのクライアント構成の詳細な説明

目次リポジトリソースを変更する起動するvue-devtoolsを置き換える予防ボーダーレスウィンドウ...