Maison > base de données > tutoriel mysql > Que se passe-t-il si une instruction DDL est exécutée au milieu de la transaction MySQL en cours ?

Que se passe-t-il si une instruction DDL est exécutée au milieu de la transaction MySQL en cours ?

王林
Libérer: 2023-08-23 17:05:02
avant
866 Les gens l'ont consulté

Que se passe-t-il si une instruction DDL est exécutée au milieu de la transaction MySQL en cours ?

Lorsqu'une instruction DDL (telle qu'une base de données CREATE ou DROP, une table CREATE, ALTER ou DROP ou une procédure stockée) est exécutée dans la transaction en cours, la transaction MySQL en cours sera validée et terminée. Toutes les modifications apportées à la base de données dans le cadre de la transaction en cours deviennent permanentes et ne peuvent pas être annulées.

Exemple

mysql> START TRANSACTION;
Query OK, 0 rows affected (0.00 sec)

mysql> INSERT INTO MARKS Values(6,'Manak','History',70);
Query OK, 1 row affected (0.26 sec)

mysql> Create table student(id int, Name Varchar(10),);
Query OK, 0 rows affected (0.84 sec)
Copier après la connexion

Comme nous pouvons le voir dans l'exemple ci-dessus, une instruction DDL est exécutée au milieu d'une transaction, cette transaction se terminera donc implicitement. MySQL enregistrera toutes les modifications et ne pourra pas revenir en arrière. Nous pouvons observer cela avec l'ensemble de résultats suivant :

mysql> Rollback;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from marks;
+------+---------+-----------+-------+
| Id   | Name    | Subject   | Marks |
+------+---------+-----------+-------+
| 1    | Aarav   | Maths     | 50    |
| 1    | Harshit | Maths     | 55    |
| 3    | Gaurav  | Comp      | 69    |
| 4    | Rahul   | History   | 40    |
| 5    | Yashraj | English   | 48    |
| 6    | Manak   | History   | 70    |
+------+---------+---------+---------+
6 rows in set (0.00 sec)
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:tutorialspoint.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal