除了 START TRANSACTION 之外,哪種語句用於開始事務?
我們還可以使用 BEGIN 語句開始一個新事務。它與 START TRANSACTION 語句相同。
示例
mysql> BEGIN; 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(2, 'Harshit','History',48); Query OK, 1 row affected (0.00 sec) mysql> ROLLBACK; Query OK, 0 rows affected (0.04 sec)
在這個示例中,事務是由 BEGIN 語句而不是 START TRANSACTION 語句發起的。然後執行兩個 INSERT 語句,然後執行一個 ROLLBACK 語句。ROLLBACK 語句將撤銷對資料庫所做的更改,這可以從以下結果集中觀察到,它顯示沒有插入新的值到表中 −
mysql> SELECT * FROM Marks; +------+---------+---------+-------+ | Id | Name | Subject | Marks | +------+---------+---------+-------+ | 1 | Aarav | Maths | 50 | | 2 | Harshit | Maths | 55 | +------+---------+---------+-------+ 2 rows in set (0.00 sec)
廣告