MySql はコミットする必要がありますか?

MySql はコミットする必要がありますか?

MySQL が挿入などの操作を実行するときにコミットする必要があるかどうかは、ストレージ エンジンによって異なります。

MyISAM などのエンジンがトランザクションをサポートしていない場合、コミットは効果がありません。

InnoDBなどのトランザクションをサポートするエンジンの場合は、トランザクションが自動トランザクション送信(コミット)をサポートしているかどうかを知る必要があります。

データベースが自動的にコミットされるかどうかを確認するには、mysql> show variables like '%autocommit%'; を使用します。オフの場合、自動的にコミットされないため、手動でコミットする必要があります (コマンドラインで「commit;」コマンドを直接使用できます)。それ以外の場合は、自動的にコミットされます。

送信されるデータには、明示的な送信、暗黙的な送信、自動送信の 3 種類があります。

これら 3 つのタイプについて以下に説明します。

明示的なコミット

COMMIT コマンドを使用して直接実行されるコミットは明示的なコミットです。

暗黙のコミット

SQL コマンドによって間接的に完了する送信は暗黙的な送信です。コマンドは次のとおりです。

ALTER、AUDIT、COMMENT、CONNECT、CREATE、DISCONNECT、DROP、EXIT、GRANT、NOAUDIT、QUIT、REVOKE、RENAME 。

自動送信

AUTOCOMMITがONに設定されている場合、挿入、変更、または削除ステートメントが実行された後、

システムが自動的に送信します。これは自動送信です。形式は次のとおりです: SQL>SET AUTOCOMMIT ON;

COMMIT / ROLLBACK コマンドを使用するときは注意してください。 COMMIT / ROLLBACK は、DML ステートメント (INSERT / DELETE / UPDATE / SELECT) を実行した後に使用されます。 DML ステートメントが実行されると、処理されたデータはロールバック セグメントに配置され (SELECT ステートメントを除く)、ユーザーによるコミット (COMMIT) またはロールバック (ROLLBACK) を待機します。ユーザーが COMMIT / ROLLBACK を実行すると、ロールバック セグメントに配置されたデータは削除されます。 (SELECT 文が実行されると、データは共有プールに保存されます。同じデータを他のユーザーにクエリ用に提供する場合、データベースにアクセスせずに共有プールから直接抽出されるため、データ クエリの速度が向上します。)

すべての DML ステートメントは明示的にコミットする必要があります。つまり、DML ステートメントの実行後に COMMIT を実行する必要があります。 DDL ステートメントなどのその他のものは暗黙的にコミットされます。つまり、これらの非 DML ステートメントを実行した後、データベースは既に暗黙的なコミットを実行しています。たとえば、CREATE TABLE スクリプトを実行した後は、テーブルが作成されているため、明示的なコミットを実行する必要はありません。

以下もご興味があるかもしれません:
  • PHP+MySQL トランザクションのロールバックとコミットの例

<<:  ReactでのDOM操作の実装

>>:  Linux\Nginx 環境での仮想ドメイン名の設定とテスト検証

推薦する

Linux環境でタイムゾーンを設定できない問題を解決

Linuxでタイムゾーンを変更する場合、常に変更することはできませんAsia/Shanghai に変...

Mysql の遅いクエリ操作の概要

MySQL の遅いクエリの説明MySQL スロー クエリ ログは、MySQL が提供するログ レコー...

Linux スレッド間の同期と排他制御の知識ポイントのまとめ

スレッドが同時に実行される場合、スレッドがリソースを競合してデータの曖昧さが生じるのを防ぐために、重...

MySQL テーブル名の大文字と小文字の選択

目次1. 大文字と小文字の区別を決定するパラメータ2. パラメータ変更に関する注意事項要約: 1. ...

HTML 再利用テクニック

HTML の再利用は、あまり話題に上らない言葉です。今日は、この問題を次のようにまとめたいと思います...

JavaScript を使用した数独の完全な実装プロセス

目次序文数独の解き方最初のボックスに記入してください2番目のボックスに記入してください3番目のボック...

mysql 結合クエリ (左結合、右結合、内部結合)

1. MySQLの一般的な接続INNER JOIN (内部結合、または等価結合): 2 つのテーブ...

CSS3 を使用して中心点の周りに要素を配置する方法の例

この記事では、CSS3 を使用して中心点を中心に要素をレイアウトする方法の例を紹介します。詳細は次の...

vue+iviewのメニューとタブの連携方法

Vue+iview メニューとタブのリンク現在、vue+iview を使用してバックエンド管理システ...

MySQL マスター/スレーブ データベース同期構成と一般的なエラー

アクセス回数が増えると、時間のかかるデータベース読み取り操作では、データベースへの負荷を軽減するため...

MySQL Innodb ストレージ構造と Null 値の保存の詳細な説明

背景:テーブルスペース: すべての INNODB データはテーブルスペース (共有テーブルスペース)...

HTMLテーブルの詳細な説明

機能: データ表示、テーブルアプリケーションシナリオ。 <table> テーブル<...

Javascript クロージャの使用シナリオの原則の詳細

目次1. 終了2. クロージャの使用シナリオ1.タイムアウトを設定する2. コールバック3. 手ぶれ...

VueとElementUIを組み合わせたスキン変更ソリューション

目次前面に書かれた解決策 1: グローバル スタイル オーバーライドを使用する (フロントエンドに共...

JavaScript データ型の詳細な説明

目次1. リテラル1.1 数値リテラル1.2 浮動小数点リテラル1.3 特別な値1.4 文字列リテラ...