MySQL でトランザクションのコミットとロールバックを実装する方法の詳細な例

MySQL でトランザクションのコミットとロールバックを実装する方法の詳細な例

最近、データベース データのスケジュールされた移行を実行する必要があります。実行プロセス中に何らかの理由で SQL ステートメントがエラーを報告してデータ転送の混乱を引き起こすのを防ぐには、スクリプトのトランザクションを制御する必要があります。

まずtran_testテーブルを作成します

テーブルtran_testを作成します( 
f1 VARCHAR(10) NULLではない、 
f2 INT(1) デフォルト NULL、 
主キー (f1) 
)エンジン=INNODB 文字セット=utf8

tran_test に 2 つのデータを挿入したいのですが、挿入中にエラーが発生しないように、トランザクション内で挿入ステートメントを制御したいと思います。

この時、何人かの方の記事を確認すると、このような回答が返ってくることが多いです。

トランザクションを開始します。  
tran_test に VALUES('A',1) を挿入します。 
tran_test に VALUES('B',2) を挿入します。 
ロールバック;

または

トランザクションを開始します。  
tran_test に VALUES('A',1) を挿入します。 
tran_test に VALUES('B',2) を挿入します。 
専念;

これらの SQL ステートメントは非常に単純に見え、実際にコミットまたはロールバックできます。

しかし、これで本当に私たちの目標は達成できるのでしょうか?答えはノーです。

たとえば、最初の段落では、正しいかどうかに関係なく、トランザクション内のすべての SQL ステートメントが ROLLBACK されます。このような絶対的なロールバックにより、SQL は無意味になります。

したがって、トランザクションを真に制御したい場合、実行される SQL に対して異常検出を実行することが私の考えです。 SQL に例外がない場合は COMMIT、例外がキャッチされた場合は ROLLBACK します。

この時点で、例外をキャプチャするためのストアド プロシージャを構築する必要があります。実行が成功した場合は COMMIT が実行され、SQL 実行が失敗した場合は ROLLBACK が実行されます。

望む効果を得るには2つの方法があります。

1 つ目は、実行する SQL の例外をキャプチャすることです。変数 t_error を定義します。例外がキャプチャされたら、t_error=1 とします。次に、t_error の条件判断を行います。t_error=1 の場合は ROLLBACK を実行し、それ以外の場合は COMMIT を実行します。

存在する場合は t_test プロシージャを削除します。 
区切り文字 // 
プロシージャ t_test() を作成する 
 始める 
  t_error INTEGER を宣言します。 
  SQLEXCEPTION の CONTINUE ハンドラーを宣言し、t_error = 1 を設定します。 
  トランザクションを開始します。 
     tran_test に VALUES('A',1) を挿入します。 
   tran_test に VALUES('B',2) を挿入します。 
     t_error = 1の場合 
       ロールバック; 
     それ以外 
       専念; 
     終了の場合; 
終わり// 
t_test() を呼び出します。

もう1つは最初のものの簡略化であり、例外がキャッチされた場合はROLLBACKが直接実行され、例外がキャッチされない場合はCOMMITが直接実行されます。

存在する場合は t_test プロシージャを削除します。 
区切り文字 // 
プロシージャ t_test() を作成する 
始める 
SQLEXCEPTION ROLLBACK の終了ハンドラを宣言します。 
トランザクションを開始します。 
tran_test に VALUES('A',1) を挿入します。 
tran_test に VALUES('B',2) を挿入します。 
専念; 
終わり// 
t_test() を呼び出す

このようにして、2 つの挿入ステートメントは 1 つのトランザクション内で実際に制御されます。

今回は上記の例をテストしていただけます。その他の補足やご質問がある場合は、編集者に直接お問い合わせください。123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL でコミットされていないトランザクションを見つけるための SQL の例の簡単な分析
  • MySQL でコミットされていないトランザクション情報を見つける方法
  • Mysql トランザクション分離レベルの読み取りコミットの詳細な説明
  • MySQL の InnoDB テーブルの書き込み速度に対するインデックスとコミット頻度の影響を調べる
  • PHP がテキストエリアデータを MySQL に送信するときに多くのスペースが発生する問題の解決方法
  • MySQLはトランザクションのコミットとロールバックの例を実装しています
  • Python は MySQL に接続し、MySQL トランザクションの例を送信します
  • JSP + MySQL 中国語の文字化け問題 投稿投稿文字化けの解決方法
  • MySQLとSpringの自動コミットの詳細な説明

<<:  EclipseのプロジェクトをTomcatに追加できない問題を解決する方法

>>:  弾幕効果を実現するためのjQuery

推薦する

Linux CentOS 6.5 ifconfig が IP を照会できない問題の解決方法

最近、何人かの友人から、仮想マシンに CentOS をインストールした後、ifconfig コマンド...

Dockerコンテナのk8sデプロイメントの実装

環境: (docker、k8s クラスター)、前回 docker で起動した Java プログラムの...

HTML のオートコンプリートを無効にして履歴を表示しないようにする

入力ボックスには、コンテンツを入力するときに常に入力履歴が表示されます。これを無効にする現在の方法は...

過去2年間のユーザーエクスペリエンス

<br />国内のウェブサイトが本格的に普及し、ユーザーエクスペリエンスに重点が置かれる...

MySQL 悲観的ロックと楽観的ロックの実装

目次序文実際の戦闘1. ロックなし2. 悲観的ロック3. 楽観的ロック要約する序文悲観的ロックと楽観...

Docker コンテナでネットワーク リクエストが遅くなる問題の解決策

Docker の使用中に、いくつかの問題が発見されました。npm install や bundle ...

マージンのマージの問題を解決する

1. 兄弟要素の余白を結合する効果は次のようになります: (2 つの間の間隔は 150 ピクセルでは...

Linux仮想マシンをWiFiに接続する方法

生活の中で、インターネットはどこにでもあります。インターネットを通じてゲームをしたり、テレビ番組を見...

MySQL の大文字と小文字の区別に関する注意

目次MySQLの大文字と小文字の区別はパラメータによって制御されますMySQLの大文字と小文字の区別...

Zabbix で複数の JVM プロセスを監視する方法

1. シナリオの説明:私たちの環境ではマイクロサービスを使用しています。各プログラムには個別のプロセ...

MySQLソートにおけるCASE WHENの使用例

序文以前のプロジェクトでは、SQL の CASE WHEN ソート関数が使用されました。ではブログメ...

Dockerを使用してブログサイトを素早く構築する方法の詳細な説明

目次1. 準備2. 展開プロセス3. アクセステストHalo は、ブログに慣れている学生に追加のオプ...

HTMLフォーム入力監視の詳細な理解

今日、入力イベントに関するブログ投稿を見て、気まぐれで関連情報を整理してみました。イベント:関数 c...

ウェブデザインにおける2種類のタブアプリケーション

現在、Web デザインではタブが広く使用されていますが、一般的に次の 2 つのタイプに分けられます。...

Ubuntu は、Mysql+Keepalived の高可用性実装 (デュアルアクティブ ホットスタンバイ) を構築します。

Mysql5.5 デュアルマシン ホットスタンバイ実装 2つのMySQLをインストールするMySQ...