Maison > base de données > tutoriel mysql > le corps du texte

我们如何实现MySQL事务?

WBOY
Libérer: 2023-09-02 11:53:02
avant
1133 人浏览过

我们如何实现MySQL事务?

我们知道,在事务中,语句是作为一个单元执行的。如果事务内的任何操作失败,则整个事务将失败并应回滚;否则,语句所做的任何更改都会保存到数据库中。为了实现事务,MySQL 提供了以下语句 -

START TRANSACTION

顾名思义,事务从此语句开始。基本上,它通知 MySQL 接下来的语句应被视为单个工作单元,直到事务结束。

COMMIT

COMMIT 语句提交对数据库的更改。换句话说,当一个事务成功完成后,应该发出 COMMIT 命令,以使所有涉及的表的更改生效。

ROLLBACK

ROLLBACK 命令撤消语句所做的任何更改,并将数据库返回到之前的状态,即事务开始时的状态。

示例

以下是展示 MySQL 事务实现的示例 -

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

mysql> INSERT INTO Marks Values(1, 'Aarav','Maths',50);
Query OK, 1 row affected (0.00 sec)

mysql> INSERT INTO Marks Values(2, 'Harshit','Maths',55);
Query OK, 1 row affected (0.00 sec)

mysql> COMMIT;
Query OK, 0 rows affected (0.06 sec)
Copier après la connexion

在此示例中,事务由 START TRANSACTION 语句启动。然后执行两个 INSERT 语句,后跟一个 COMMIT 语句。 COMMIT 语句会将更改保存到数据库,可以从以下结果集中观察到这些更改,该结果集显示值已插入到表中 -

mysql> SELECT * FROM Marks;
 +------+---------+---------+-------+
| Id   | Name    | Subject | Marks |
+------+---------+---------+-------+
| 1    | Aarav   | Maths   | 50    |
| 2    | Harshit | Maths   | 55    |
+------+---------+---------+-------+
2 rows in set (0.00 sec)

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

mysql> INSERT INTO Marks Values(1, 'Aarav','History',40);
Query OK, 1 row affected (0.00 sec)

mysql> INSERT INTO Marks Values(1, 'Harshit','History',48);
Query OK, 1 row affected (0.00 sec)

mysql> ROLLBACK;
Query OK, 0 rows affected (0.04 sec)
Copier après la connexion

在此示例中,事务由 START TRANSACTION 语句启动。然后执行两个 INSERT 语句,后跟一个 ROLLBACK 语句。 ROLLBACK 语句将撤消对数据库所做的更改,可以从以下结果集中观察到,该结果集显示没有新值插入到表中 -

mysql> SELECT * FROM Marks;
+------+---------+---------+-------+
| Id   | Name    | Subject | Marks |
+------+---------+---------+-------+
| 1    | Aarav   | Maths   | 50    |
| 1    | Harshit | Maths   | 55    |
+------+---------+---------+-------+
2 rows in set (0.00 sec)
Copier après la connexion

以上是我们如何实现MySQL事务?的详细内容。更多信息请关注PHP中文网其他相关文章!

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
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!